在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Netmiko+excle定時檢測接口狀態

jf_yLA7iRus ? 來源:知乎楓嵐 ? 作者:知乎楓嵐 ? 2022-10-19 09:15 ? 次閱讀

一、前言:在本人看著群里的大佬紛紛分享自己的文章和一些運維思路,深知只有用出來,寫出來,分享出來,跟大家一起交流,這個程序和學習到的新知識才算真正掌握了。在這里非常感謝王印王老師@弈心、朱嘉盛老師@朱嘉盛以及群里的各位大佬不遺余力地分享著自己的文章。針對python的學習主要源于他們的專欄。

二、實驗背景:

前一段時間,機房剛剛建完,但是弱電做的網線不太行,出現兩次網線問題,這不是要了命了么。領導說,想辦法如果交換機網線出問題了你得能知道。我想說,咱們用個運維平臺不行嗎,我又想我們今年手里的服務器資源只剩下4核,6G了。
行,那就寫個腳本吧。本次實驗以H3C設備為基礎。

就是說寫一個只要接口狀態發生變化就能有郵件通知你,而且還有excle作為佐證。

我認為本次實驗僅僅適用于十幾二十臺小環境的網絡。(而且有點錢上個平臺不比嘛強)

三、需求分析

首先首次使用腳本之后,excle里工作表收集的都是當前所有設備的UP的接口。

81f94692-4f45-11ed-a3b6-dac502259ad0.jpg

工作簿底下的工作表的是所有設備,以命名+IP的形式存在。

822ed49c-4f45-11ed-a3b6-dac502259ad0.jpg

工作簿底下是所有的設備

然后如果有一個接口的狀態出現了變化,只要有變化,Link這一列對應的狀態就會變色,還會發郵件以工作簿為附件。

824087fa-4f45-11ed-a3b6-dac502259ad0.jpg

82770eec-4f45-11ed-a3b6-dac502259ad0.jpg

如果你是就想人為規劃斷開這個接口,不是鏈路的損壞,那么在下次執行這個腳本的時候,不是UP接口就不存在了。

82a1a1e8-4f45-11ed-a3b6-dac502259ad0.jpg

如果這個接口從ADM狀態又回復為UP,那么也會發郵件,并且攜帶工作簿為附件。

82affcb6-4f45-11ed-a3b6-dac502259ad0.jpg

81f94692-4f45-11ed-a3b6-dac502259ad0.jpg

最后設置成1分鐘執行一次,放在服務器里。

每次執行程序只會維護第一次執行程序輸出的這一張表,所以不用擔心文件太多。

三、代碼分析

3.1完整代碼

先上完整代碼,然后再進行分析。

#coding=gbk
importre
importsmtplib
importthreading
importtime
fromemail.mime.applicationimportMIMEApplication
fromemail.mime.multipartimportMIMEMultipart
fromemail.mime.textimportMIMEText
frompprintimportpprint
fromqueueimportQueue

fromnetmikoimportConnectHandler
fromopenpyxl.reader.excelimportload_workbook
fromopenpyxl.workbookimportWorkbook
fromopenpyxl.stylesimportPatternFill,Border,Side,Font

threads=[]#用于多線程
ip_list=open('ip_file.txt')#IP地址先行放入文件中
dims={}#用于對工作表中自動設置最大行寬
content=""#用于輸出在郵箱中的內容
defssh_seesion(ip,ouput,):
globalcontent,sheet
#這幾個列表是寫入工作表的先行條件,也就是工作表的每一列,先把想寫入工作表的每一列的內容寫入列表,然后再遍歷列表把內容寫入工作表
interface_list=[]
link_list=[]
speed_list=[]
description_list=[]

connection_info={'device_type':'hp_comware',
'ip':ip,
'username':'xxxxx',
'password':'xxxxxx'}

withConnectHandler(**connection_info)asconn:
output=conn.send_command("displayinterfacebrief",use_textfsm=True)
sysname=conn.send_command('displaycurrent-configuration|includesysname')
name=re.search(r's+S+s+(S+)',sysname).groups()[0]
#pprint(output)

try:
sheet=wb[name+'_'+ip]#調用自己的那一張表
#先給逼刪了
column_B=sheet['B']
foriincolumn_B:
#print(i.value)
ifi.valuenotin('Link','UP'):
num=re.search('d+',i.coordinate).group()#找到需要刪的那一行
print(num)
sheet.delete_rows(int(num))
except:
pass

#取出接口up的
foriinoutput:
ifi.get('link')=='UP':
interface_list.append(i.get('interface'))
link_list.append(i.get('link'))
speed_list.append(i.get('speed'))
description_list.append(i.get('description'))
#判斷這次interface跟上次也就是表格里的有沒有區別以是否是UP的為前提不是UP的或者多了UP的或者少了UP的只要變化就要被記錄


ifstr(name+'_'+ip)inwb.sheetnames:#如果這個表存在就讓里原本有的接口進入列表
sheet_pre=wb[name+'_'+ip]
column_A=sheet_pre['A']#取出以前的表的第一列
sheet_pre_A1=[i.valueforiincolumn_A]
sheet_pre_A1.remove('Interfaces')#遍歷第一列的時候會有抬頭也就是Interfaces'需要把這個去掉
#print(sheet_pre_A1)#sheet_pre_A1里是上一次表格里有的接口列表
#print(interface_list)#interface_list里是這一次想放入表格里的UP的接口的列表
#取出兩個列表的差集,這個差集是現在UP的和表里的差集
sheet_dif=list(set(sheet_pre_A1)^(set(interface_list)))#把兩個表中變化的接口放入sheet_dif這個列表里
print(sheet_dif)#至此有變化的且不是UP的接口就進入列表了
iflen(sheet_dif)!=0:#如果這個列表里有數據就發郵箱
content=content+f"{name}{str(sheet_dif)}接口發生了變化
'"#配合發郵件的

foriinoutput:#為了把差集的接口情況寫入列表
forpinsheet_dif:
ifp==i.get('interface')andi.get('link')!='UP':#找到這個不是UP的接口各種情況還寫進去
interface_list.append(i.get('interface'))
link_list.append(i.get('link'))
speed_list.append(i.get('speed'))
description_list.append(i.get('description'))
content=content+i.get('interface')+'接口由UP變成了'+i.get('link')+'
'
elifp==i.get('interface')andi.get('link')=='UP':
content=content+i.get('interface')+'接口UP了'+'
'


font=Font(name="微軟雅黑",bold=True)#字體加粗
yellowFill=PatternFill(start_color='FFFF00',end_color='FFFF00',fill_type='solid')#黃色
thin_border=Border(left=Side(style='thin'),right=Side(style='thin'),top=Side(style='thin'),
bottom=Side(style='thin'))#有邊框
SpringGreen=PatternFill(start_color='3CB371',end_color='3CB371',fill_type='solid')#黃色

ifstr(name+'_'+ip)inwb.sheetnames:#如果表格存在直接往里寫
row_numbers=list(range(2,len(output)+2))#只能從第二行開始
forinterface,rowinzip(interface_list,row_numbers):
sheet.cell(row=row,column=1,value=interface)
forlink,rowinzip(link_list,row_numbers):
sheet.cell(row=row,column=2,value=link)
forspeed,rowinzip(speed_list,row_numbers):
sheet.cell(row=row,column=3,value=speed)
fordescription,rowinzip(description_list,row_numbers):
sheet.cell(row=row,column=4,value=description)

#往里寫完之后查看B1這列然后找到不是UP的給賦值綠色
column_B=sheet['B']
foriincolumn_B:
#print(i.value)
ifi.valuenotin('Link','UP'):
print(i.coordinate)#查找到接口有問題的坐標
sheet[i.coordinate].fill=SpringGreen


else:#如果表格不存在則創建表格
sheet=wb.create_sheet(name+'_'+ip)#這里的sheet相當于JT-6-1F-DAS-1這個表格
columns=['A1','B1','C1','D1']
cells=['Interfaces','Link','Speed','Description']
fori,pinzip(columns,cells):
#放入表格中
sheet[i]=p
sheet[i].fill=yellowFill
sheet[i].font=font

row_numbers=list(range(2,len(output)+2))#只能從第二行開始
forinterface,rowinzip(interface_list,row_numbers):
sheet.cell(row=row,column=1,value=interface)
forlink,rowinzip(link_list,row_numbers):
sheet.cell(row=row,column=2,value=link)
forspeed,rowinzip(speed_list,row_numbers):
sheet.cell(row=row,column=3,value=speed)
fordescription,rowinzip(description_list,row_numbers):
sheet.cell(row=row,column=4,value=description)


forrowinsheet.rows:
#print(row)
forcellinrow:
#print(cell.value)
cell.border=thin_border
ifcell.value:
dims[cell.column_letter]=max((dims.get(cell.column_letter,0),len(str(cell.value))))

forcol,valueindims.items():
sheet.column_dimensions[col].width=value+3


defsend_email(sender,receicer,password,content):
#這份代碼比較標準了,可以直接用了

#發件人郵箱
sender=sender
#收件人郵箱
receiver=receicer
#抄送人郵箱
#acc='xxxxxxxx@qq.com'
#郵件主題
subject='服務器運行情況'

#郵箱密碼(授權碼)
password=password

#郵件設置
msg=MIMEMultipart()
msg['Subject']=subject#主題
msg['to']=receiver#接收者
#msg['acc']=acc#抄送者
msg['from']="信息化員工"#發件人

#郵件正文
content=content

#添加郵件正文:
msg.attach(MIMEText(content,'plain','utf-8'))#content是正文內容,plain即格式為正文,utf-8是編碼格式

#添加附件
#注意這里的文件路徑是斜杠
file_name=r'E:python	est	est功能腳本接口up_down	est_openpyxl.xlsx'
file_name_list=file_name.split('\')[-1]#獲得文件的名字
xlsxpart=MIMEApplication(open(file_name,'rb').read())
xlsxpart.add_header('Content-Disposition','attachment',filename=file_name_list)
#服務端向客戶端游覽器發送文件時,如果是瀏覽器支持的文件類型,一般會默認使用瀏覽器打開,比如txt、jpg等,會直接在瀏覽器中顯示,如果需要提示用戶保存,就要利用Content-Disposition進行一下處理,關鍵在于一定要加上attachment
msg.attach(xlsxpart)

#設置郵箱服務器地址以及端口
smtp_server="smtp.qq.com"
smtp=smtplib.SMTP(smtp_server,25)#'smtp.qq.com'是QQ郵箱發郵件的服務器,用新浪郵箱就是'smtp.sina.com',就是smtp加上你們郵箱賬號@符號后面的內容。端口默認是25。
#smtp.set_debuglevel(1)#顯示出交互信息

#登陸郵箱
smtp.login(sender,password)

#發送郵件
smtp.sendmail(sender,receiver.split(','),msg.as_string())
#receiver.split(',')+acc.split(',')是['xxxxxxxx@qq.com','xxxxxxxx@qq.com']

#斷開服務器鏈接
smtp.quit()

print(f"程序于{time.strftime('%X')}執行開始
")
#記錄開始時間
start_time=time.time()

#注意邏輯關系先創建工作簿再進入多線程最后保存工作簿
try:#如果存在這個表格就直接打開,如果部存在就創建
wb=load_workbook('test_openpyxl.xlsx')
ws=wb.active
except:#創建表格如果存在就不創建
wb=Workbook()
wb.remove(wb['Sheet'])
ws=wb.active

foripsinip_list.readlines():
t=threading.Thread(target=ssh_seesion,args=(ips.strip(),Queue()))
t.start()
threads.append(t)


foriinthreads:
i.join()
#加入檢查功能


iflen(content)!=0:
print(content)
send_email("xxxx@qq.com","xxxx@qq.com","jveyorpbogllijhj",content)


end_time=time.time()-start_time

wb.save('test_openpyxl.xlsx')#保存工作表
print(f'總共耗時{round(end_time,2)}秒')
print(f"程序于{time.strftime('%X')}執行結束
")
TestFSM模板
ValueInterface(S+)
ValueLink(UP|DOWN|ADM|Stby)
ValueSpeed(.*G|auto)
ValueDescription(S+|s+)

Start
^s*${Interface}s+${Link}s+${Speed}((a)|s*)+s+S+s+S+s+S+s+${Description}->Record

3.2分析

特別詳細的分析寫在了代碼的注釋中。這里只是對思路的分析。

首先就是登錄設備,然后調用TestFSM模板做解析,再取出設備的名字。use_textfsm=True的用法參照朱嘉盛:《網絡工程師的Python之路》(nornir實驗10,聯動Textfsm,ntc-template,華為)

defssh_seesion(ip,ouput,):
globalcontent,sheet
#這幾個列表是寫入工作表的先行條件,也就是工作表的每一列,先把想寫入工作表的每一列的內容寫入列表,然后再遍歷列表把內容寫入工作表
interface_list=[]
link_list=[]
speed_list=[]
description_list=[]

connection_info={'device_type':'hp_comware',
'ip':ip,
'username':'xxxxxx',
'password':'123'}

withConnectHandler(**connection_info)asconn:
output=conn.send_command("displayinterfacebrief",use_textfsm=True)
sysname=conn.send_command('displaycurrent-configuration|includesysname')
name=re.search(r's+S+s+(S+)',sysname).groups()[0]
#pprint(output)

首先明確這個腳本是一分鐘執行一次,然后是在工作簿中找到此次登錄的設備的工作表,然后對其進行刪除操作,刪除工作表中存在的不是UP的接口的那一行,因為這個工作簿的目的是存接口為UP的接口的信息,那么之前存在不是UP的接口的內個工作簿呢?通過郵箱發出來了。因為如果第一次執行這個程序,那么肯定不存在這個表,所以用個try……except。

i.coordinate用來獲取一個格子的坐標的。比如輸出結果就是B11這樣。

try:
sheet=wb[name+'_'+ip]#調用自己的那一張表
#先給逼刪了
column_B=sheet['B']
foriincolumn_B:
#print(i.value)
ifi.valuenotin('Link','UP'):
num=re.search('d+',i.coordinate).group()#找到需要刪的那一行
print(num)
sheet.delete_rows(int(num))
except:
passtry:
sheet=wb[name+'_'+ip]#調用自己的那一張表
#先給逼刪了
column_B=sheet['B']
foriincolumn_B:
#print(i.value)
ifi.valuenotin('Link','UP'):
num=re.search('d+',i.coordinate).group()#找到需要刪的那一行
print(num)
sheet.delete_rows(int(num))
except:
pass
defssh_seesion(ip,ouput,):
globalcontent,sheet
#這幾個列表是寫入工作表的先行條件,也就是工作表的每一列,先把想寫入工作表的每一列的內容寫入列表,然后再遍歷列表把內容寫入工作表
interface_list=[]
link_list=[]
speed_list=[]
description_list=[]

connection_info={'device_type':'hp_comware',
'ip':ip,
'username':'xxxxxx',
'password':'123'}

withConnectHandler(**connection_info)asconn:
output=conn.send_command("displayinterfacebrief",use_textfsm=True)
sysname=conn.send_command('displaycurrent-configuration|includesysname')
name=re.search(r's+S+s+(S+)',sysname).groups()[0]
#pprint(output)
然后取出接口為UP的接口的信息,放入表格中,因為這個工作簿的目的是存接口為UP的接口的信息。
#取出接口up的
foriinoutput:
ifi.get('link')=='UP':
interface_list.append(i.get('interface'))
link_list.append(i.get('link'))
speed_list.append(i.get('speed'))
description_list.append(i.get('description'))
#判斷這次interface跟上次也就是表格里的有沒有區別以是否是UP的為前提不是UP的或者多了UP的或者少了UP的只要變化就要被記錄

再然后就是把表中原有的接口記錄在sheet_pre_A1這個例表中,然后與剛才新構成的接口全為UP的列表interface_list取差集,差集包含什么?包含可能有新接口UP了,可能有舊接口不UP了。如果差集中有接口,就寫入content中,為了發郵箱用。

然后判斷差集里面接口的狀態,是又其他狀態變為UP,還是由UP變為了其他狀態。還是寫如content中,發郵箱用。

ifstr(name+'_'+ip)inwb.sheetnames:#如果這個表存在就讓里原本有的接口進入列表
sheet_pre=wb[name+'_'+ip]
column_A=sheet_pre['A']#取出以前的表的第一列
sheet_pre_A1=[i.valueforiincolumn_A]
sheet_pre_A1.remove('Interfaces')#遍歷第一列的時候會有抬頭也就是Interfaces'需要把這個去掉
#print(sheet_pre_A1)#sheet_pre_A1里是上一次表格里有的接口列表
#print(interface_list)#interface_list里是這一次想放入表格里的UP的接口的列表
#取出兩個列表的差集,這個差集是現在UP的和表里的差集
sheet_dif=list(set(sheet_pre_A1)^(set(interface_list)))#把兩個表中變化的接口放入sheet_dif這個列表里
print(sheet_dif)#至此有變化的且不是UP的接口就進入列表了
iflen(sheet_dif)!=0:#如果這個列表里有數據就發郵箱
content=content+f"{name}{str(sheet_dif)}接口發生了變化
'"#配合發郵件的

foriinoutput:#為了把差集的接口情況寫入列表
forpinsheet_dif:
ifp==i.get('interface')andi.get('link')!='UP':#找到這個不是UP的接口各種情況還寫進去
interface_list.append(i.get('interface'))
link_list.append(i.get('link'))
speed_list.append(i.get('speed'))
description_list.append(i.get('description'))
content=content+i.get('interface')+'接口由UP變成了'+i.get('link')+'
'
elifp==i.get('interface')andi.get('link')=='UP':
content=content+i.get('interface')+'接口UP了'+'
'
第一行加粗并且黃色,有狀態變化的那一格是綠色。
font=Font(name="微軟雅黑",bold=True)#字體加粗
yellowFill=PatternFill(start_color='FFFF00',end_color='FFFF00',fill_type='solid')#黃色
thin_border=Border(left=Side(style='thin'),right=Side(style='thin'),top=Side(style='thin'),
bottom=Side(style='thin'))#有邊框
SpringGreen=PatternFill(start_color='3CB371',end_color='3CB371',fill_type='solid')#黃色
然后開始往工作表里寫東西,如果工作表存在,那么直接寫,相當于覆蓋。
寫完之后查看B1這一列,也就是Link這一列,不是UP的給賦值綠色。
ifstr(name+'_'+ip)inwb.sheetnames:#如果表格存在直接往里寫
#在寫之前先刪除#去表格里找,如果檢測到上次接口不是up則把這個接口刪掉,不是從python的列表里刪掉,直接從表格里刪掉

row_numbers=list(range(2,len(output)+2))#只能從第二行開始
forinterface,rowinzip(interface_list,row_numbers):
sheet.cell(row=row,column=1,value=interface)
forlink,rowinzip(link_list,row_numbers):
sheet.cell(row=row,column=2,value=link)
forspeed,rowinzip(speed_list,row_numbers):
sheet.cell(row=row,column=3,value=speed)
fordescription,rowinzip(description_list,row_numbers):
sheet.cell(row=row,column=4,value=description)
#往里寫完之后查看B1這列然后找到不是UP的給賦值綠色
column_B=sheet['B']
foriincolumn_B:
#print(i.value)
ifi.valuenotin('Link','UP'):
print(i.coordinate)#查找到接口有問題的坐標
sheet[i.coordinate].fill=SpringGreen
如果表格不存在則創建表格再往里寫,服務于第一次執行程序
else:#如果表格不存在則創建表格
sheet=wb.create_sheet(name+'_'+ip)#這里的sheet相當于JT-6-1F-DAS-1這個表格
columns=['A1','B1','C1','D1']
cells=['Interfaces','Link','Speed','Description']
fori,pinzip(columns,cells):
#放入表格中
sheet[i]=p
sheet[i].fill=yellowFill
sheet[i].font=font

row_numbers=list(range(2,len(output)+2))#只能從第二行開始
forinterface,rowinzip(interface_list,row_numbers):
sheet.cell(row=row,column=1,value=interface)
forlink,rowinzip(link_list,row_numbers):
sheet.cell(row=row,column=2,value=link)
forspeed,rowinzip(speed_list,row_numbers):
sheet.cell(row=row,column=3,value=speed)
fordescription,rowinzip(description_list,row_numbers):
sheet.cell(row=row,column=4,value=description)
一段以一列中最寬的一格為標準,自動變換列寬的代碼
forrowinsheet.rows:
#print(row)
forcellinrow:
#print(cell.value)
cell.border=thin_border
ifcell.value:
dims[cell.column_letter]=max((dims.get(cell.column_letter,0),len(str(cell.value))))

forcol,valueindims.items():
sheet.column_dimensions[col].width=value+3
然后是發郵件的函數,就不做過多介紹了
defsend_email(sender,receicer,password,content):

最后執行主函數

先是創建工作簿,因為可能工作簿已經存在了,所以用try,然后用了多線程快一點,再然后判斷content里是否有內容,只要接口發生了狀態變化content中就有變化,content有變化就發郵件,郵件附件是工作簿。

print(f"程序于{time.strftime('%X')}執行開始
")
#記錄開始時間
start_time=time.time()

#注意邏輯關系先創建工作簿再進入多線程最后保存工作簿
try:#如果存在這個表格就直接打開,如果部存在就創建
wb=load_workbook('test_openpyxl.xlsx')
ws=wb.active
except:#創建表格如果存在就不創建
wb=Workbook()
wb.remove(wb['Sheet'])
ws=wb.active

foripsinip_list.readlines():
t=threading.Thread(target=ssh_seesion,args=(ips.strip(),Queue()))
t.start()
threads.append(t)


foriinthreads:
i.join()
#加入檢查功能


iflen(content)!=0:
print(content)
send_email("1123824309@qq.com","1123824309@qq.com","jveyorpbogllijhj",content)


end_time=time.time()-start_time

wb.save('test_openpyxl.xlsx')#保存工作表
print(f'總共耗時{round(end_time,2)}秒')
print(f"程序于{time.strftime('%X')}執行結束
")

3.3思路合集

82c9c25e-4f45-11ed-a3b6-dac502259ad0.jpg

四、測試

首先用四個設備做測試

82d72ca0-4f45-11ed-a3b6-dac502259ad0.jpg

第一次執行成功輸出工作簿,下面的工作表示以名字_ip展現

82e908da-4f45-11ed-a3b6-dac502259ad0.jpg

然后然別斷開兩個設備的兩個接口之后再執行一次程序

8304208e-4f45-11ed-a3b6-dac502259ad0.jpg

831bca4a-4f45-11ed-a3b6-dac502259ad0.jpg

如果此時你就是想把這個接口認為donw掉,然后再執行一次程序,也不會有郵件發出,down掉的接口的那一行也被刪除了

8337a878-4f45-11ed-a3b6-dac502259ad0.jpg

如果此時接口恢復UP,會發郵件通知,而且UP的接口也進入到工作表中了。

836b444e-4f45-11ed-a3b6-dac502259ad0.jpg

839fc1d8-4f45-11ed-a3b6-dac502259ad0.jpg

五、總結

最后把這個腳本仍在服務器里,一分鐘執行一次,這樣一個低成本的監控交換機接口狀態變化的腳本就寫完了,其實還有點小問題,比如果接口狀態不是up了,在輸出工作表時,不是UP的那一行就變為了最后一行。

在上大學有一門課叫軟件工程,我記得老師教的一句話是”程序開發時要高內聚,低耦合”然后再看一眼我的代碼,真的是有些丑陋,寫程序時常常思維不清晰,邏輯不準確。反正,這個腳本在我們現有的網絡里能用。

審核編輯 :李倩


聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • ADM
    ADM
    +關注

    關注

    0

    文章

    30

    瀏覽量

    16030
  • 弱電
    +關注

    關注

    0

    文章

    79

    瀏覽量

    14762
  • python
    +關注

    關注

    56

    文章

    4799

    瀏覽量

    84820

原文標題:網工Python之路之Netmiko+excle定時檢測接口狀態

文章出處:【微信號:釋然IT雜談,微信公眾號:釋然IT雜談】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    如何檢測HDMI接口是否正常工作

    檢測HDMI接口是否正常工作,可以通過以下幾種方法: 一、觀察外觀 首先,檢查HDMI接口的物理狀態。如果接口有明顯的物理損傷,如裂痕、變形
    的頭像 發表于 11-27 15:18 ?2261次閱讀

    CS1-A磁性開關主要靠什么檢測狀態使用

    磁性開關通過磁感應原理檢測物體的狀態或位置,并將檢測到的信息轉換為電信號進行傳輸和處理。這種檢測方式具有高精度、可靠性和易于安裝維護等優點,在工業自動化、安全系統和傳感器等領域發揮著重
    的頭像 發表于 11-04 18:22 ?300次閱讀

    使用MSP430掃描接口進行旋轉檢測

    電子發燒友網站提供《使用MSP430掃描接口進行旋轉檢測.pdf》資料免費下載
    發表于 10-23 10:22 ?0次下載
    使用MSP430掃描<b class='flag-5'>接口</b>進行旋轉<b class='flag-5'>檢測</b>

    接口的控制與狀態寄存器什么作用

    接口的控制與狀態寄存器(Control and Status Registers,簡稱CSR)是計算機系統中用于控制和監控硬件設備操作的寄存器。它們是硬件設備與其驅動程序之間的橋梁,允許軟件控制硬件
    的頭像 發表于 10-17 10:42 ?510次閱讀

    電流檢測器件的數字接口

    電子發燒友網站提供《電流檢測器件的數字接口.pdf》資料免費下載
    發表于 09-19 13:21 ?0次下載
    電流<b class='flag-5'>檢測</b>器件的數字<b class='flag-5'>接口</b>

    ON狀態下高壓側開關開路負載檢測應用說明

    電子發燒友網站提供《ON狀態下高壓側開關開路負載檢測應用說明.pdf》資料免費下載
    發表于 09-13 10:19 ?0次下載
    ON<b class='flag-5'>狀態</b>下高壓側開關開路負載<b class='flag-5'>檢測</b>應用說明

    請問電池在充電狀態怎么檢測電池實際電壓?

    電池在充電狀態怎么檢測電池實際電壓?
    發表于 07-26 06:29

    定時器的工作方式介紹

    定時器是計算機和嵌入式系統中常見的一種硬件模塊,用于實現定時和計數功能。定時器的工作方式通常由一組寄存器來控制,這些寄存器定義了定時器的配置參數和工作
    的頭像 發表于 07-12 10:29 ?1047次閱讀

    武漢凱迪正大分享高壓電纜狀態檢測檢測知識

    高壓電纜狀態檢測是指通過各種技術手段對高壓電纜的運行狀態進行實時監測、評估和預測以確保電纜的安全可靠運行。本文將依照武漢凱迪正大的經驗探討高壓電纜狀態
    的頭像 發表于 06-25 09:14 ?400次閱讀
    武漢凱迪正大分享高壓電纜<b class='flag-5'>狀態</b><b class='flag-5'>檢測</b>的<b class='flag-5'>檢測</b>知識

    使用定時器的編碼器接口模式,打開定時器的溢出中斷,當定時器上溢出和下溢出是,是否都會產生溢出中斷?

    使用定時器的編碼器接口模式,打開定時器的溢出中斷,當定時器上溢出和下溢出是,是否都會產生溢出中斷
    發表于 05-24 07:41

    s7200定時器的五種故障介紹

    定時器或CPU故障:如果定時器本身或PLC的CPU出現故障,也可能導致定時器無法復位。此時,需要檢查定時器和CPU的工作狀態,確保其正常運行
    的頭像 發表于 04-03 17:08 ?2554次閱讀

    圓心定位大揭秘!如何快速檢測按鈕居中狀態

    相信大家對以下這個按鍵一定不陌生,大多數電子產品上都少不了這個按鍵,我們通常把它稱為【電源鍵】;電源鍵在電子設備中的應用非常廣泛,是用戶與設備交互的重要接口之一。Q如何做到每個電源鍵的定位都如此精準
    的頭像 發表于 04-02 08:23 ?303次閱讀
    圓心定位大揭秘!如何快速<b class='flag-5'>檢測</b>按鈕居中<b class='flag-5'>狀態</b>?

    斷電延時定時器指令TOF

    TOF指令用于允許輸入端斷開后的單一間隔定時。當定時器的輸入端IN為ON時,TOF的狀態位為ON,其常開觸點閉合,常閉觸點斷開,但是定時器的當前值仍為0。
    的頭像 發表于 04-01 11:40 ?3131次閱讀
    斷電延時<b class='flag-5'>定時</b>器指令TOF

    window10下載了STLINK接口檢測,卻檢查不到接口怎么解決?

    window10下載了STLINK接口檢測,卻檢查不到接口,開發板沒辦法使用自帶的STLINK仿真器,想要用自己的JLINK仿真器應該怎么接線
    發表于 03-29 07:36

    Harmony 鴻蒙應用級變量的狀態管理

    應用級變量的狀態管理 在前面的章節中,已經講述了如何管理頁面級變量的狀態,本章將說明如何管理應用級變量的狀態,具體接口說明請參考應用級變量的狀態
    的頭像 發表于 01-24 21:30 ?516次閱讀
    Harmony 鴻蒙應用級變量的<b class='flag-5'>狀態</b>管理
    主站蜘蛛池模板: 亚洲成a人片毛片在线| 天天操天天看| 国产亚洲精品久久久极品美女| 久久性感美女视频| 天天做天天摸| 久久久xxx| 亚洲五月六月丁香激情| 午夜影院免费观看| 丁香六月婷婷精品免费观看| 色激情网| 亚洲三级黄色| 国产精品久久久久国产精品三级| 1314酒色| 免费免费啪视频在线| 精品一区二区在线观看| 日日草夜夜草| 午夜影院在线观看视频| 色极影院| 亚洲成a人不卡在线观看| 在线观看国产一级强片| 高清欧美性xxxx成熟| 99涩涩| 狼人久久尹人香蕉尹人| 婷婷亚洲综合五月天在线| 丁香花在线影院观看在线播放| 99久久伊人| a爱视频| 天堂8中文在线最新版在线| 777奇米影视一区二区三区| 韩国特黄特色a大片免费| 六月婷操| 久久久久四虎国产精品| www.91久久| 4hc44四虎www视频| 欧美午夜精品一区二区三区| 欧美黄色片视频| 黄色网址网站在线观看| 在线观看三级视频| 亚洲精品香蕉婷婷在线观看| 午夜性福利| 色婷五月|