失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > python如何以表格形式打印输出

python如何以表格形式打印输出

时间:2022-06-02 07:24:31

相关推荐

python如何以表格形式打印输出

近日有个小需求,要求收集统计一些信息上报,并直接在后台控制台打印,写入日志

为了美观,需要以表格形式展现数据,形如

虽说可以用 prettytable 实现这个效果,不过还得安装这个库,需求比较简单就不考虑安装第三方依赖了,所以得自己写

照着这个图,可以发现几个关键的实现点

由数据项的各个属性,整理出表头

计算每个属性对应的最大宽度,作为每列的宽度

每列左右留一些空

表头上下,以及数据项末尾添加一行 --±- 外围

循环每项,各项左右使用 | 做外围

需支持居中显示或左对齐,这些可以通过计算列的总长度,再补空格来实现 利用 .center .ljust 这些快捷方法

最终效果呢,还是阔以的

#!/usr/bin/python# -*- coding: utf-8 -*-import timeimport json# 数据项timingInfo = [{'url': '/ccc/article/details/11','duration(ms)': 121.12,'start(ms)': 222,'type': 'html','size(kb)': 22.01}, {'url': '/nd-element-in-list-to-another-list-of-strings','duration(ms)': 121.22,'start(ms)': 3332,'type': 'css','size(kb)': 22.01}, {'url': '/path2','duration(ms)': '121.12434234 (1212312.12 + 121212)','start(ms)': 3332,'type': 'css','size(kb)': 22.01}, {'url': '/nd-element-in-list-to-another-list-of-strings','duration(ms)': 121.42323423423,'start(ms)': 3332,'type': 'css','size(kb)': 22.01}, {'url': 'path2','duration(ms)': '121.11 (111.11 + 20)','start(ms)': 3332,'type': 'css','size(kb)': 22.01}]# 提取表头keyHeader = timingInfo[0].keys()# 存放每列的最大长度keyMaxLen = {}for item in timingInfo:for i,h in enumerate(keyHeader):# 计算每个属性对应的最大长度maxLen = max(len(h), len(str(item[h])))if keyMaxLen.get(h, None):maxLen = max(maxLen, keyMaxLen[h])keyMaxLen[h] = maxLenprint keyMaxLen#def printGroup(group):for item in group:print '\r'for i,h in enumerate(keyHeader):itemLen = keyMaxLen.get(h, str(h)) + 4# 补空位并居中s = str(item[h]).center(itemLen, '-' if item[h] == '-' else ' ')icon = '|'if item[h] == '-':icon = '+'s = (icon if i == 0 else '') + s[1:len(s)] + iconprint s,print '\r'print '\n[timing info]'# 占位项tag = {}for i,h in enumerate(keyHeader):tag[h] = '-'# 前后添上timingInfo.insert(0, tag)timingInfo.append(tag)# 第一行需要先单独打印出来printGroup([tag])# 再单独打印表头for i,h in enumerate(keyHeader):# 留空位4itemLen = keyMaxLen.get(h, str(h)) + 4# 快捷居中并补空位 左对齐可使用 ljust之类s = h.center(itemLen)s = ('|' if i == 0 else '') + s[1:len(s)] + '|'print s,# 打印后面的数据项,包括两条 --+--占位printGroup(timingInfo)

上面这个是直接打印出来的,print 默认一行打印,要做到按项拼接,就得在print后面加个逗号,

另外,这样只能在控制台输出,而如果要打印到日志中,就得换种做法了

使用字符串拼接,整个输出就是一个字符串,从头拼到末尾就ok了

当然嫌麻烦的话,也可以直接装了prettytable 直接用也行

import prettytable as pt# tb = pt.PrettyTable( ["City name", "Area", "Population", "Annual Rainfall"])tb = pt.PrettyTable()tb.field_names = ["City name", "Area", "Population", "Annual Rainfall"]tb.add_row(["Adelaide",1295, 1158259, 600.5])tb.add_row(["Brifasdfae",5905, 1857594, 1146.4])tb.add_row(["Darwin", 112, 120900, 171423423423423424.7])tb.add_row(["Hobart", 1357, 205556,619.5])print(tb)

转载自:/imwtr/p/11062308.html

如果觉得《python如何以表格形式打印输出》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。