统计系统剩余的内存
1、思路
首先对文件遍历;判断当有MemFree这一行开头的,执行下面的语句,line.split()[1]默认以空格为分隔符,取1列的值;最后取2位小数点
数据类型转换计算(计算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()