linux系统使用python获取cpu信息脚本分享

复制代码 代码如下:
#!/usr/bin/env Python
from __future__ import print_function
from collections import OrderedDict
import pprint

def CPUinfo():
    \’\’\’ Return the information in /proc/CPUinfo
    as a dictionary in the following format:
    CPU_info[\’proc0\’]={…}
    CPU_info[\’proc1\’]={…}
    \’\’\’
    CPUinfo=OrderedDict()
    procinfo=OrderedDict()

    nprocs = 0
    with open(\’/proc/CPUinfo\’) as f:
        for line in f:
            if not line.strip():
                # end of one processor
                CPUinfo[\’proc%s\’ % nprocs] = procinfo
                nprocs=nprocs+1
                # Reset
                procinfo=OrderedDict()
            else:
                if len(line.split(\’:\’)) == 2:
                    procinfo[line.split(\’:\’)[0].strip()] = line.split(\’:\’)[1].strip()
                else:
                    procinfo[line.split(\’:\’)[0].strip()] = \’\’

    return CPUinfo

if __name__==\’__main__\’:
    CPUinfo = CPUinfo()
    for processor in CPUinfo.keys():
        print(CPUinfo[processor][\’model name\’])

简单说明一下清单 1,读取/proc/CPUinfo 中的信息,返回 list,每核心一个 dict。其中 list 是一个使用方括号括起来的有序元素集合。List 可以作为以 0 下标开始的数组。Dict 是 Python 的内置数据类型之一, 它定义了键和值之间一对一的关系。OrderedDict 是一个字典子类,可以记住其内容增加的顺序。常规 dict 并不跟踪插入顺序,迭代处理时会根据键在散列表中存储的顺序来生成值。在 OrderedDict 中则相反,它会记住元素插入的顺序,并在创建迭代器时使用这个顺序。
可以使用 Python 命令运行脚本 CPU1.py 结果见图