日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > python >内容正文

python

python 获取Dmidecode 输出的系统硬件信息

發(fā)布時間:2023/12/9 python 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python 获取Dmidecode 输出的系统硬件信息 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

目的:

熟悉利用python 分析文本的信息。分析的文件信息是通過dmidecode 工具抓取的系統(tǒng)硬件信息。


本文結(jié)構(gòu):

(1) 分析dmidecode 工具的輸出信息結(jié)構(gòu)

(2) 分別用兩種方式對dmidecode 輸出的信息實現(xiàn)抓取,獲取Manufacturer、Product Name和?Serial Number.



  • dmidecode 輸出信息分析

  • ? dmidecode 是系統(tǒng)的工具,如果沒有安裝,需要先安裝。在我的機器上的Dmidecode 版本:

    ?

    ?安裝的方式也很簡單,用命令:yum ?install -y ?dmidecode 即可。

    ??

    ?Dmidecode 工具主要是將系統(tǒng)的DMI數(shù)據(jù)庫的信息進行解碼,并以可讀的信息顯示。輸出的信息包括了BIOS、系統(tǒng)、主板、處理器、內(nèi)存、緩存、序列號、產(chǎn)品名稱和廠家信息等。DMI就是收集系統(tǒng)信息的管理系統(tǒng),它遵循SMBOIS協(xié)議,是主板制造商需嚴格遵守的協(xié)議。


    ?dmidecode 輸出的信息比較多,一屏并不能顯示完整,只能用"dmidecode| less" 處理一下:

    ?


    這篇文章需要處理收集的信息在"System Information" 這部分:


    2. 方法實現(xiàn)

    回到這篇文章討論的目的,python 的實現(xiàn)方式就是:

    (1) 執(zhí)行命令"dmidecode" ,將它的輸出信息讀出并保存。使用python 的subprocess 模塊。

    (2) 然后遍歷文本。


    根據(jù)遍歷文本的方式,給出兩個實現(xiàn)的版本:

    版本1:對dmidecode 信息整體保存,然后逐行遍歷

    #!/usr/bin/env??python?""" file_name:?dmi.py """from??subprocess??import???Popen,?PIPEp?=?Popen(["dmidecode"],?stdout=PIPE,?stderr=PIPE) line_in?=?False lines?=?[]?? dmi_dic?=?{}while?True:line??=??p.stdout.readline()???#逐行遍歷if??line.startswith('System?Information'):???#找到了"System?Information"?的開始line_in?=?Truecontinueif?line_in:if?line??!=?‘\n’:??#在"System?Information"?里遍歷lines.append(line)else:break???#如果到了"System?Information"?的換行,則退出while?循環(huán)print??lines


    暫時,先看這部分的輸出結(jié)果:

    如圖,輸出的列表,最好能將它變成字典保存,變成字典的形式就很方便輸出了。轉(zhuǎn)換成字典時,需要將每個元素頭尾的'\t'和'\n'去除,然后按":"符號分割,分別就是字典的key 和value了。繼續(xù)完善上面的腳本,為了完整性,腳本還是會從開始給出:

    #!/usr/bin/env??python?""" file_name:?dmi.py """from??subprocess??import???Popen,?PIPEp?=?Popen(["dmidecode"],?stdout=PIPE,?stderr=PIPE) line_in?=?False lines?=?[]?? dmi_dic?=?{}while?True:line??=??p.stdout.readline()???#逐行遍歷if??line.startswith('System?Information'):???#找到了"System?Information"?的開始line_in?=?Truecontinueif?line_in:if?line??!=?‘\n’:??#在"System?Information"?里遍歷lines.append(line)else:break???#如果到了"System?Information"?的換行,則退出while?循環(huán)#print??lines""" 這里用到列表生成式,遍歷lines,?對元素i?去除頭尾的'\t'和'\n',然后以‘:’分割,得到兩個元素的列表, 對于[['a',?'1'],?['b',?'2']]這種形式的列表,用dict()方法就可以構(gòu)造出一個字典,如下: " dmi_dic?=?dict([i.strip().split(':')??for?i?in?lines?])???"""現(xiàn)在的dmi_dic?字典已經(jīng)很接近最終的結(jié)果了,但是它的每個value?的最前面還帶有空格,所以還需要將value?前的空格去除""" for???k,??v??in??dmi_dic.items():dmi_dic[k]??=?v.strip()"""最后找到需要的Manufacturer、Product?Name和?Serial?Number的值""" dmi?=?{} dmi['Manufacturer']??=??dmi_dic['Manufacturer'] dmi['Product?Name']??=??dmi_dic['Product?Name'] dmi['Serial?Number']?=??dmi_dic['Serial?Number']print??dmi

    最后,驗證結(jié)果:

    如圖,已經(jīng)將需要的三個數(shù)據(jù)保存到字典里了。



    版本2:對dmidecode 信息整體進行分割,然后以列表的形式進行分析

    #!/usr/bin/env??python""" file_name:?dmi_t.py """from?subprocess?import?Popen,?PIPEdef??getData():p?=?Popen(['dmidecode'],?stdout=PIPE,?stderr=PIPE)data?=?p.stdout.read().split()return?dataif??__name__?==?'__main__':print?getData()


    執(zhí)行腳本,先驗證一下,輸出的結(jié)果是什么樣子的:

    如圖,列表的每一個元素就是dmidecode 的每一行,在上圖找到了"System Information" 的這一行。"System Information\n" 的下一行是以'\t'開頭的,對應(yīng)就是原來dmidecode 的縮進的空格。再一直往下看,就會找到'\n'它對應(yīng)著"System Information"結(jié)束后的換行。接著看到'Handle 0x0002...' 這是新的一段信息了。那么,抓取信息就可以用'\t'作為判斷了。

    這里有一個判斷的技巧要說明一下,例如: 如果a='wedf', 則not a.strip() 返回的是False. 如果a='\n' , 那么not a.strip() 就返回True. 也就是說,字符串進行strip() 方法后,如果還是空字符則not a.strip() 就返回True,如果不為空,則not a.strip() 返回False. 現(xiàn)在繼續(xù)完善腳本:

    #!/usr/bin/env??python""" file_name:?dmi_t.py """from?subprocess?import?Popen,?PIPEdef??getData():p?=?Popen(['dmidecode'],?stdout=PIPE,?stderr=PIPE)data?=?p.stdout.read().split()return?datadef??parseData(data):line_in?=?Falselines?=?[]for?line??in?data:if?line.starswith('System?Information'):line_in?=?Truecontinueif?line_in:if?not?line.strip():??#如果遍歷到空行,即新的一段信息前,則可以退出循環(huán)了breakelse:lines.append(line)????def??getDmi(lines):dmi_dic?=?{}dmi?=?{}dmi_dic?=?dict([i.strip().split(":")??for?i?in?lines?])for?k,?v?in?dmi_dic.items():dmi_dic[k]?=?v.strip()dmi['Manufacturer']?=?dmi_dic['Manufacturer']????dmi['Product?Name']?=?dmi_dic['Product?Name']dmi['Serial?Number']?=?dmi_dic['Serial?Number']return?dmi????????????????????if??__name__?==?'__main__':data???=??getData()lines?=?parseData(data)print?getDmi(lines)

    看結(jié)果:


    總結(jié):

    熟悉利用python 腳本對字符文本信息的處理方法


    轉(zhuǎn)載于:https://blog.51cto.com/hellocjq/1864742

    總結(jié)

    以上是生活随笔為你收集整理的python 获取Dmidecode 输出的系统硬件信息的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。