python如何以表格形式打印输出
好久不见,风水轮流转,我竟然写写写python了
近日有个小需求,要求收集统计一些信息上报,并直接在后台控制台打印,写入日志
为了美观,需要以表格形式展现数据,形如

虽说可以用 prettytable 实现这个效果,不过还得安装这个库,需求比较简单就不考虑安装第三方依赖了,所以得自己写
照着这个图,可以发现几个关键的实现点
1. 由数据项的各个属性,整理出表头
2. 计算每个属性对应的最大宽度,作为每列的宽度
3. 每列左右留一些空
4. 表头上下,以及数据项末尾添加一行 --+-- 外围
5. 循环每项,各项左右使用 | 做外围
6. 需支持居中显示或左对齐,这些可以通过计算列的总长度,再补空格来实现 利用 .center .ljust 这些快捷方法
最终效果呢,还是阔以的

#!/usr/bin/python
# -*- coding: utf-8 -*- import time
import json # 数据项
timingInfo = [{
'url': 'https://aaa.bbb.net/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] = maxLen print 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)] + icon
print 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):
# 留空位4
itemLen = 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)
python如何以表格形式打印输出的更多相关文章
- jsp+oracle实现数据库内容以表格形式在前台显示(包含分页)
jsp+oracle实现数据库内容以表格形式在前台显示(包含分页) 在文件夹内新增list_emp.jsp 代码如下: <%@ page contentType="text/html& ...
- python 处理 Excel 表格
see: http://www.cnblogs.com/sunada2005/p/3193300.html 一.可使用的第三方库 python中处理excel表格,常用的库有xlrd(读excel)表 ...
- python 对Excel表格的写入
python对Excel表格写入需要导入xlrd ,和xlutils两个库 from xlrd import open_workbook from xlutils.copy import copy o ...
- word模板导出的几种方式:第一种:占位符替换模板导出(只适用于word中含有表格形式的)
1.占位符替换模板导出(只适用于word中含有表格形式的): /// <summary> /// 使用替换模板进行到处word文件 /// </summary> public ...
- Python 利用Python操作excel表格之openyxl介绍Part2
利用Python操作excel表格之openyxl介绍 by:授客 QQ:1033553122 欢迎加入全国软件测试交流qq群(群号:7156436) ## 绘图 c = LineChart() ...
- Python 利用Python操作excel表格之openyxl介绍Part1
利用Python操作excel表格之openyxl介绍 by:授客 QQ:1033553122 欢迎加入全国软件测试交流qq群(群号:7156436),免费获取以下性能监控工具(类似Nmon精简版) ...
- 后端list集合中的数据传递到前台HTML中显示(表格形式)
关键字:web项目中前后台数据传递问题 在学习web项目的过程中,我们肯定会遇到前后台数据交换问题.这个问题我也思考了很久,今天借此总结一下.由于博主水平有限,如有不当之处,还请大家多多指正,,废话不 ...
- 利用PHP实现登录与注册功能以及使用PHP读取mysql数据库——以表格形式显示数据
登录界面 <body><form action="login1.php" method="post"><div>用户名:&l ...
- 【转】python操作excel表格(xlrd/xlwt)
[转]python操作excel表格(xlrd/xlwt) 最近遇到一个情景,就是定期生成并发送服务器使用情况报表,按照不同维度统计,涉及python对excel的操作,上网搜罗了一番,大多大同小异, ...
随机推荐
- Python进阶-XIV 面向对象初步
1.面向对象的引入 def Person(*args): ''' 定义一个人 :param args: 人的属性 :return: 人的所有属性的字典 ''' info = {} info['name ...
- Emu8086三种格式的代码-(顺序,分支,循环)
这个学期准备考研,于是就没有怎么听别的课,现在临近期末,汇编成了个难题.下面是我学校的实验报告 做一个复习的记录吧,下面的代码都是在Emu8086上运行出来的代码 下面先介绍一下,汇编里面的格式问题 ...
- Shell编程——环境变量
在Shell程序启动时会自动定义一组变量,这组变量就是环境变量,系统中的所有命令都可以使用这些变量参数. 1.如果在父Shell定义环境变量,在子Shell中也能查看到. (1)父Shell与子She ...
- Linux学习笔记-第2天- 新的开始
迟到且稀疏的笔记,希望自己今年会有所突破.加油
- Genome Sequencing of MuseumSpecimens Reveals Rapid Changes in the Genetic Composition of Honey Bees in California
文章地址:https://academic.oup.com/gbe/article/10/2/458/4810442#supplementary-data Abstract 在自然生态系统和管理生态系 ...
- Redis面试题(46题)
1.什么是Redis?简述它的优缺点? Redis 的全称是:Remote Dictionary.Server,本质上是一个 Key-Value 类型的内存数据库,很像memcached,整个数据库统 ...
- Python程序设计例题
例一:蒙特卡罗方法求解 π 值 from random import random from math import sqrt from time import clock DARTS=1000 hi ...
- [LeetCode] 891. Sum of Subsequence Widths 子序列宽度之和
Given an array of integers A, consider all non-empty subsequences of A. For any sequence S, let the ...
- [LeetCode] 15. 3Sum 三数之和
Given an array S of n integers, are there elements a, b, c in S such that a + b + c = 0? Find all un ...
- Java高级工程师常见问题
MySQL数据库调优 定位慢查询得到生产环境那些sql语句响应慢,根据执行计划进行分析调优事物管理索引结构(B+树)平衡二叉树.B树.B+树分库分表后,如何解决查询 使用第三方数据库中间件( ...