说明
这种方式比直接在shell里面写awk之类的要友好很多,毕竟到了python里面处理就容易了。
内容
1 函数
os的这个函数很有意思,可以认为通过os.popen执行后会产生了一个类似文本文件的内容。
import os
# 执行shell命令,返回文本段
def popen(some_cmd):
with os.popen(some_cmd) as f:
res = f.read()
return res
import re
# 按连续空格或者制表符分割
def split_by_re(the_pat, x):
return re.split(the_pat, x)
2 例子
执行docker ps
出来的结果是这样的
之前以为不同字段之间使用制表符分割的,但不晓得为啥都变成了空格:所以采用连续空格进行分割
# 先将获得的数据按换行符分开
data_list= resp_dict['data'].split('\n')
# 按连续空格或者制表符分割
trailing_blanks = re.compile(r"\s{2,}|\t");
res_list = []
for x in data_list:
res_list.append(split_by_re(trailing_blanks, x))
# 转为表格
import pandas as pd
res_df = pd.DataFrame(res_list[1:], columns = res_list[0])
可以看到,基本完美的解成表格了。