统计系统剩余的内存

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

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

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

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

数据类型转换计算(计算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()