功能
方法
项目 | 代码 |
---|---|
按行/列构建表格 | tb=pt.PrettyTabel(), tb.add_row(), tb.add_col() |
操作类:排序/删除 | tb.sortby=xx, tb.delete_row(ind) |
文件导出 导入类:html | tb.get_html_string(), pt.from_html_one(tb_str) |
运行效果
代码
import prettytable as pt
#1# 按照行构建表格
tb = pt.PrettyTable()
tb.field_names = ['name','age','occupation','salary']
tb.add_row(['Wang',18, 'Doctor', 30000])
tb.add_row(['Zhang',42, 'Programer', 40000])
tb.add_row(['Chen', 33, 'Teacher', 5000])
print('按照行构建')
print(tb)
#2# 按照列构建表格
tb_col = pt.PrettyTable()
field_names = ['name','age','occupation','salary']
tb_col.add_column(field_names[0],['Wang','Zhang', 'Chen'])
tb_col.add_column(field_names[1],[18,42,33])
tb_col.add_column(field_names[2], ['Doctor','Programer','Teacher'])
tb_col.add_column(field_names[3], [30000,40000,5000])
print('按照列构建')
print(str(tb_col))
#3# 删除操作
tb.del_row(2)
print('删除一行\n', tb)
tb.add_row(['Chen', 33, 'Teacher', 5000])
print('恢复原表\n',tb)
#4# 排序
tb.sortby="salary"
tb.reversesort = True #反转排序顺序
print('按照薪水降序排序后\n',tb)
tb.sortby='age'
print('按照年龄升序排序后\n',tb)
#5# 输出为HTML文件
print(tb.get_html_string())
html_file = open('tb_html.html','w')
html_file.writelines(tb.get_html_string())
html_file.close()
#6# 从html文件再读入
html_in = open('tb_html.html','r')
tb_html = html_in.read()
print('html读入表格\n',pt.from_html_one(tb_html))