脚本之家,脚本语言编程技术及教程分享平台!
分类导航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服务器之家 - 脚本之家 - Python - pandas dataframe添加表格框线输出的方法

pandas dataframe添加表格框线输出的方法

2021-05-26 00:27q24499417 Python

今天小编就为大家分享一篇pandas dataframe添加表格框线输出的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

dataframe添加到texttable里面,实现格式化输出。

?
1
2
3
4
data=[{"name":"amay","age":20,"result":80},
   {"name":"tom","age":32,"result":90}]
df=pd.dataframe(data,columns=['name','age','result'])
print(df)

datafrma如下,现在要给其添加上表格框线。利用texttable。

pandas dataframe添加表格框线输出的方法

?
1
2
3
4
5
6
7
8
9
10
tb=texttable()
tb.set_cols_align(['l','r','r'])
tb.set_cols_dtype(['t','i','i'])
tb.header(df.columns.get_values())
tb.add_rows(df.values,header=false)
'''
header=false表示不将第一参数的第一行作为标题,
这样我们之前的添加的标题就会起作用了
'''
print(tb.draw())

上面就是设置表格输出的对其格式,以及列的数据类型。‘set_cols_align是对水平位置上的左中右靠齐。‘l'表示向左。‘c'表示居中,'r'向右。

set_col_dtype用于设置列的数据类型、数据类型的对应如:

?
1
2
3
4
5
['t', # text
'f', # float (decimal)
'e', # float (exponent)
'i', # integer
'a' # automatic]

tb.header(df.columns.get_values()) 这句是添加标题。 tb.add_rows(df.values,header=false) 这句是添加数据行。默认会将数据行的第一行作为标题。如果我们不设置header=false的话,返回结果:

pandas dataframe添加表格框线输出的方法

之前指定的标题没起作用。应该是将第一行作为标题了。

设置了header=false后结果就出来了:

pandas dataframe添加表格框线输出的方法

最后发一下完整的代码:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
# -*- coding: utf-8 -*-
"""
created on tue jan 8 16:47:17 2019
python version:3.6.7
@author: fanxiaolei
"""
import pandas as pd
from texttable import texttable
data=[{"name":"amay","age":20,"result":80},
   {"name":"tom","age":32,"result":90}]
df=pd.dataframe(data,columns=['name','age','result'])
print(df)
print('添加表格线之后:')
tb=texttable()
tb.set_cols_align(['l','r','r'])
tb.set_cols_dtype(['t','i','i'])
tb.header(df.columns.get_values())
tb.add_rows(df.values,header=false)
'''
header=false表示不将第一参数的第一行作为标题,
这样我们之前的添加的标题就会起作用了
'''
print(tb.draw())

以上这篇pandas dataframe添加表格框线输出的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/qq_24499417/article/details/86185080

延伸 · 阅读

精彩推荐