网站首页 > java教程 正文
简介
这个脚本通过获取/etc/os-release文件中的系统版本信息,通过Linux系统中的/proc目录中的cpuinfo和meminfo文件获取cpu和内存的信息,在使用系统内置的os和platform库获取系统名称和主机名,内核版本等信息。并使用prettytable库将结果在命令行中形成表格进行输出。本脚本使用与Linux系统,并在Debian和ReaHat系的发行版本下测试运行正常。
下面是脚本运行的结果:
完整的代码
下面是全部的代码:
import os
import platform
import prettytable
def systemInfo():
system = os.popen("cat /etc/os-release|grep -E \"^NAME\"|awk -F \"\\\"\" '{print $2}'").readline()
sysversion = os.popen("cat /etc/os-release|grep -E \"^VERSION\"|awk -F \"\\\"\" '{print $2}'").readline()
hostname = platform.node()
version = platform.release()
framework = platform.machine()
cpumodel = os.popen("cat /proc/cpuinfo |grep \"model name\"|awk -F : '{print $2}'").readline()
cpucores = os.popen('grep "processor" /proc/cpuinfo |wc -l').readline()
memory = os.popen("cat /proc/meminfo |grep MemTotal|awk '{print $2$3}'").readline()
swapmemory = os.popen("cat /proc/meminfo |grep SwapTotal|awk '{print $2$3}'").readline()
table = prettytable.PrettyTable()
table.field_names = ['名称','值']
table.add_row(['系统名称',system.replace('\n','')])
table.add_row(['系统版本',sysversion.replace('\n','')])
table.add_row(['主机名',hostname])
table.add_row(['内核版本',version])
table.add_row(['CPU架构',framework])
table.add_row(['CPU型号',cpumodel.replace('\n','')])
table.add_row(['CPU核心数',cpucores.replace('\n','')])
table.add_row(['物理内存',memory.replace('\n','')])
table.add_row(['交换空间',swapmemory.replace('\n','')])
print(table)
if __name__ == '__main__':
systemInfo()
代码解析
第1~3行代码
import os
import platform
import prettytable
这是三个需要用到的库的导入,os和platform是系统自带的库,不用安装,直接import导入就可以。prettytable是一个第三方的库,需要安装才可以使用,否则脚本会报错。安装的命令是pip install prettytable。
第30~31行代码
if __name__ == '__main__':
systemInfo()
可以理解为运行这个文件时的主入口,在python中,文件独立运行时,它的魔法函数 __name__ 会返回 __main__ 而在该文件被其他文件引用调用的时候,则不是返回 __main__ 。这个入口的意思就是,运行这个脚本文件的时候,就执行 systemInfo() 函数。函数在上面的第5~28行中已经定义了。
第5行代码
def systemInfo():
定义了一个名为systemInfo的函数,这个函数的内容都必须是在缩进(默认为四个空格)里面,如果没有写在缩进里面的内容,会被解析器认为是函数外的内容。下面6~28行的内容,就是因为行首有四个空格的缩进,所以是函数systemInfo的内容。
第6~7行代码
system = os.popen("cat /etc/os-release|grep -E \"^NAME\"|awk -F \"\\\"\" '{print $2}'").readline()
sysversion = os.popen("cat /etc/os-release|grep -E \"^VERSION\"|awk -F \"\\\"\" '{print $2}'").readline()
python中,要直接执行命令行命令可以使用os库中的popen()函数,然后在里面写命令行的命令就行。通过readline()可以获取到执行后的结果 Linux系统里面的/etc/os-release文件记录了系统的信息,包括系统名称、系统版本号、该系统的官方网址等信息。 上面的代码,大部分的功能是直接通过shell命令来进行查看文件,查找出NAME、VERSION开头的行,再将得到的信息用awk分隔取第二列的内容。python指负责获取结果后赋值给变量,system的数据是获取系统名称,sysversion的数据是获取系统的版本号。
第8~10行代码
hostname = platform.node()
version = platform.release()
framework = platform.machine()
系统的主机名、系统内核版本号、CPU的架构,可以直接使用python内置的platform库的node()、release()、machine()三个函数来获得,就可以不用去查看系统的文件。
第11~14行代码
cpumodel = os.popen("cat /proc/cpuinfo |grep \"model name\"|awk -F : '{print $2}'").readline()
cpucores = os.popen('grep "processor" /proc/cpuinfo |wc -l').readline()
memory = os.popen("cat /proc/meminfo |grep MemTotal|awk '{print $2$3}'").readline()
swapmemory = os.popen("cat /proc/meminfo |grep SwapTotal|awk '{print $2$3}'").readline()
获取CPU和内存的信息是查看/proc目录下的对应cpuinfo和meminfo文件对应的信息行。cpu的类型直接看model name即可,但是多少核心数需要自己统计,因为cpuinfo里面。一个核心或者线程会记录一份信息,从processor 0开始,一直累加下去。所以统计有多少行processor,就可以知道有多少个核心。meminfo里面记录的内存大小的计数单位是kb。
第16~24行代码
table = prettytable.PrettyTable()
table.field_names = ['名称','值']
table.add_row(['系统名称',system.replace('\n','')])
table.add_row(['系统版本',sysversion.replace('\n','')])
table.add_row(['主机名',hostname])
table.add_row(['内核版本',version])
table.add_row(['CPU架构',framework])
table.add_row(['CPU型号',cpumodel.replace('\n','')])
table.add_row(['CPU核心数',cpucores.replace('\n','')])
table.add_row(['物理内存',memory.replace('\n','')])
table.add_row(['交换空间',swapmemory.replace('\n','')])
赋值一个名为table的变量,这个变量是初始化一个prettytable的表格。第14行,给表格的field_names赋值,可以理解为给这个表格的表格头的列名值,用一个list表示,有多少列就在list中写多少个元素;第15~24行add_row()是将上面获取到的数据组合后逐行插入到表格中,一行数据需要执行一遍,里面的数据同样是写成一个list。每个元素对应上面field_names的列。
第28行代码
print(table)
将上面组合并美化为表格的内容输出到命令行。也就是最开始图片里面那样的输出结果。
猜你喜欢
- 2024-12-25 Python exe 文件反编译为 Python 脚本
- 2024-12-25 Python实用脚本技术及示例 python脚本例子
- 2024-12-25 Python:11个比较好用的自带脚本工具
- 2024-12-25 使用python自动化脚本执行shell命令,提前两小时下班(5)
- 2024-12-25 python脚本控制安卓手机,可以用来做什么你知道吗?
- 2024-12-25 Python番外篇之代码编译与字节码 python如何生成字节码文件
- 2024-12-25 在 Java 代码中来一段 JavaScript?聊聊 Flowable 中的脚本任务
- 2024-12-25 小白必备:如何用auto-py-to-exe轻松打包 Python 脚本
- 2024-12-25 三十个常见的python脚本,别再弄错,会吃亏的,附视频教程
- 2024-12-25 python生成脚本与部署的方案 python生成脚本与部署的方案怎么写
你 发表评论:
欢迎- 04-27微服务部署架构设计详解(图文全面总结)
- 04-27Java微服务架构选型与对比:一场技术流派的巅峰对决
- 04-27微服务架构下Java的最佳实践
- 04-27Java微服务架构选型:优雅拆分与高效整合
- 04-27微服务架构下的Java代码拆分策略:像拼图一样构建系统
- 04-27微服务架构下的Java最佳实践
- 04-27微服务架构下Java的挑战与机遇
- 04-27微服务架构下Java事务管理的艺术
- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)