统计系统剩余的内存、数据类型转换计算(计算mac地址)、数据类型转换(列表与字典相互转换)

简介:

统计系统剩余的内存

1、思路
首先对文件遍历;判断当有MemFree这一行开头的,执行下面的语句,line.split()[1]默认以空格为分隔符,取1列的值;最后取2位小数点

统计系统剩余的内存、数据类型转换计算(计算mac地址)、数据类型转换(列表与字典相互转换)

计算:
统计系统剩余的内存、数据类型转换计算(计算mac地址)、数据类型转换(列表与字典相互转换)

统计系统剩余的内存、数据类型转换计算(计算mac地址)、数据类型转换(列表与字典相互转换)

数据类型转换计算(计算mac地址)

需要:有时候我们要把不同的数据类型做一起计算,这时就需要把两个不同的数据类型转换为同种数据类型,否则不同的数据类型不能做计算,比如,字符串之间是不能做加减乘除运算的,必须转化为数值才可以做运算
1、字符串转换为列表

In [1]: s = 'abc'

In [2]: list(s)
Out[2]: ['a', 'b', 'c']

In [3]: str1='ABCDEF'

In [4]: list(str1)
Out[4]: ['A', 'B', 'C', 'D', 'E', 'F']

2、字符串转换为元组

In [5]: tuple(str1)
Out[5]: ('A', 'B', 'C', 'D', 'E', 'F')

3、元组又转换为字符串

In [7]: t
Out[7]: ('A', 'B', 'C', 'D', 'E', 'F')

In [8]: ''.join(t)
Out[8]: 'ABCDEF'

4、列表转换为字符串

In [12]: l
Out[12]: ['A', 'B', 'C', 'D', 'E', 'F']

In [13]: ''.join(l)
Out[13]: 'ABCDEF'

5、元组转换为列表

In [14]: t
Out[14]: ('A', 'B', 'C', 'D', 'E', 'F')

In [15]: list(t)
Out[15]: ['A', 'B', 'C', 'D', 'E', 'F']

6、列表转换为元组

In [16]: l
Out[16]: ['A', 'B', 'C', 'D', 'E', 'F']

In [17]: tuple(l)
Out[17]: ('A', 'B', 'C', 'D', 'E', 'F')

7、字典转换为列表

In [18]: dict1={'name':'jack','age':'11'}

In [19]: dict1.items()
Out[19]: [('age', '11'), ('name', 'jack')]

8、列出目录
In [29]: import os
Out[29]: 
['efi',
'grub2',
'grub',
'.vmlinuz-3.10.0-693.el7.x86_64.hmac']

9、16进制转化为十进制
In [29]: int('a', 16)
Out[29]: 10

In [30]: int('ab', 16)
Out[30]: 171

10进制转化为16进制
In [37]: hex(123)
Out[37]: '0x7b'

10、列表转化为字典
In [34]: list1 = [('a', 1), ('b', 2)]

In [35]: dict(list1)
Out[35]: {'a': 1, 'b': 2}

#比如mac='00:0c:29:ba:27:23',下一位就是'00:0c:29:ba:27:24'
macaddr='00:0c:29:ba:27:ab'
prefix_max=macaddr[:-3] #00:0c:29:ba:27
last_two=macaddr[-2:] #23
plus_one=int(last_two,16) + 1 #将16进制转化为10进制
if plus_one in range(10): #如果0~9的数
new_last_two=hex(plus_one)[2:] #将10进制转化为16进制
new_last_two='0'+new_last_two #当plus_one=0~9时,可以前面加上0:,符合mac规范
else: #如果10以上的数,比如hex(12)='0xc'
new_last_two=hex(plus_one)[2:] #取[2:],就是c
if len(new_last_two) == 1: #len(c)=1,前面加上0;0c,否则就不加
new_last_two='0'+new_last_two
new_mac=prefix_max+':'+new_last_two
print new_mac.upper()










本文转自方向对了,就不怕路远了!51CTO博客,原文链接:http://blog.51cto.com/jacksoner/2056007 ,如需转载请自行联系原作者


相关文章
|
1月前
|
关系型数据库 MySQL 数据库
【Mac os系统】安装MySQL数据库
本文详细介绍了在Mac OS系统上安装MySQL数据库的步骤,包括下载、安装、配置环境变量、启动服务、授权设置以及解决常见问题,并提供了一些常用的MySQL命令。
59 0
【Mac os系统】安装MySQL数据库
|
1月前
|
iOS开发 MacOS
【Mac系统】解决Vscode中LeetCode插件不能刷剑指offer题库
文章讨论了解决Mac系统中Vscode里LeetCode插件无法刷剑指Offer题库的问题,并提供了一些相关的使用技巧和资源链接。
96 1
|
1月前
【科研技巧】Mac系统如何给Endnote 20安装GB/T中文文献格式以及利用Endnote在Word中插入参考文献
在Mac系统下给Endnote 20安装GB/T中文文献格式的步骤以及如何利用Endnote在Word中插入符合GB/T格式的参考文献。
119 5
【科研技巧】Mac系统如何给Endnote 20安装GB/T中文文献格式以及利用Endnote在Word中插入参考文献
|
1月前
mac系统使用NTFS移动硬盘只读问题
mac系统使用NTFS移动硬盘只读问题
52 4
|
4月前
|
编解码 开发工具 Android开发
Android获取设备各项信息(设备id、ip地址、设备名称、运行商、品牌、型号、分辨率、处理器、国家码、系统语言、网络类型、oaid、android版本、操作系统版本、mac地址、应用程序签名..)2
Android获取设备各项信息(设备id、ip地址、设备名称、运行商、品牌、型号、分辨率、处理器、国家码、系统语言、网络类型、oaid、android版本、操作系统版本、mac地址、应用程序签名..)2
236 2
|
1月前
|
TensorFlow 算法框架/工具 Python
【Mac 系统】解决VSCode用Conda成功安装TensorFlow但程序报错显示红色波浪线Unable to import ‘tensorflow‘ pylint(import-error)
本文解决在Mac系统上使用VSCode时遇到的TensorFlow无法导入问题,原因是Python解析器未正确设置为Conda环境下的版本。通过在VSCode左下角选择正确的Python解析器,即可解决import TensorFlow时报错和显示红色波浪线的问题。
46 9
|
1月前
【科研技巧】Mac 系统如何给Endnote 20添加某篇文献信息和附加PDF文件
Mac系统下使用Endnote 20添加文献信息和PDF文件的详细步骤,包括下载.enw文件和在Endnote中导入这些文件的方法。
70 6
|
1月前
|
芯片
【PCB设计】Mac系统Autodesk EAGLE PCB使用入门教程
Mac系统下使用Autodesk EAGLE PCB设计软件的基本教程,包括软件的安装、常用命令和工具的使用方法。
63 4
|
1月前
|
iOS开发 MacOS Python
【Mac 系统】解决已有清华镜像但出现CondaHTTPError: HTTP 000 CONNECTION FAILED for url
在尝试使用清华镜像创建conda环境时遇到下载超时问题,通过删除原有镜像并添加针对Mac OS的清华镜像解决了该问题。
65 3
|
1月前
|
Linux
【Linux 或Mac系统】自动生成项目结构目录并放在README.md文件中
如何在Linux或Mac系统中使用tree命令自动生成项目结构目录,并将其格式化后放入项目的README.md文件中以展示项目结构。
71 1