用Python怎样处理Excel表格,方法和代码是什么
Admin 2022-07-25 群英技术资讯 369 次浏览
一个测试有两个sheet页的Excel测试文件 test.xlsx
import pandas as pd file1 = pd.ExcelFile('D:\\data\\py\\test.xlsx') file2 = pd.read_excel('D:\\data\\py\\test.xlsx') print(file)
<pandas.io.excel._base.ExcelFile object at 0x0000021DE525DF88> -----------------分割线--------------------- 姓名 年龄 性别 住址 0 张三 7 男 NaN 1 李四 6 男 NaN 2 王芳 6 女 NaN
pd.read_excel读出来是一个dataframe可以直接打印出内容,但是只能读取一个sheet页,默认第一个sheet页
@Appender(_read_excel_doc) @deprecate_kwarg("skip_footer", "skipfooter") def read_excel( io, sheet_name=0, header=0, names=None, index_col=None, usecols=None, squeeze=False, dtype=None, engine=None, converters=None, true_values=None, false_values=None, skiprows=None, nrows=None, na_values=None, keep_default_na=True, verbose=False, parse_dates=False, date_parser=None, thousands=None, comment=None, skip_footer=0, skipfooter=0, convert_float=True, mangle_dupe_cols=True, **kwds ): for arg in ("sheet", "sheetname", "parse_cols"): if arg in kwds: raise TypeError( "read_excel() got an unexpected keyword argument " "`{}`".format(arg) ) if not isinstance(io, ExcelFile): io = ExcelFile(io, engine=engine) elif engine and engine != io.engine: raise ValueError( "Engine should not be specified when passing " "an ExcelFile - ExcelFile already has the engine set" ) return io.parse( sheet_name=sheet_name, header=header, names=names, index_col=index_col, usecols=usecols, squeeze=squeeze, dtype=dtype, converters=converters, true_values=true_values, false_values=false_values, skiprows=skiprows, nrows=nrows, na_values=na_values, keep_default_na=keep_default_na, verbose=verbose, parse_dates=parse_dates, date_parser=date_parser, thousands=thousands, comment=comment, skipfooter=skipfooter, convert_float=convert_float, mangle_dupe_cols=mangle_dupe_cols, **kwds )
pd.ExcelFile 返回值是一个Excel对象,不能直接用,但是可以读取整个Excel内容
file = pd.ExcelFile('D:\\data\\py\\test.xlsx')
sheet页名称
print(file.sheet_names)
['一年级', '二年级']
遍历读取每个sheet页的内容
for name in file.sheet_names: _df = pd.read_excel(file,name) print(_df)
姓名 年龄 性别 住址 0 张三 7 男 NaN 1 李四 6 男 NaN 2 王芳 6 女 NaN 姓名 年龄 性别 0 李明 8 男 1 刘敏 8 女 2 张强 7 男
将两个sheet页的内容合并,并添加一列内容为sheet页名称
df_list=[] for name in file.sheet_names: _df = pd.read_excel(file,name) _df['班级']=name df_list.append(_df) df = pd.concat([_df for _df in df_list],sort=False) print(df)
姓名 年龄 性别 住址 班级 0 张三 7 男 NaN 一年级 1 李四 6 男 NaN 一年级 2 王芳 6 女 NaN 一年级 0 李明 8 男 NaN 二年级 1 刘敏 8 女 NaN 二年级 2 张强 7 男 NaN 二年级
忽略掉原来的index
df = pd.concat([_df for _df in df_list],ignore_index=True,sort=False) print(df)
姓名 年龄 性别 住址 班级 0 张三 7 男 NaN 一年级 1 李四 6 男 NaN 一年级 2 王芳 6 女 NaN 一年级 3 李明 8 男 NaN 二年级 4 刘敏 8 女 NaN 二年级 5 张强 7 男 NaN 二年级
修改列名为英文
df = df.rename(columns={'姓名': 'name', '年龄': 'age', '性别': 'sex', '住址': 'address', '班级': 'class'}) print(df)
name age sex address class 0 张三 7 男 NaN 一年级 1 李四 6 男 NaN 一年级 2 王芳 6 女 NaN 一年级 3 李明 8 男 NaN 二年级 4 刘敏 8 女 NaN 二年级 5 张强 7 男 NaN 二年级
将df保存为CSV、Excel文件
df.to_csv('../data/sheet合并.csv',index=False) df.to_excel('../data/sheet合并.xls',index=True)
可以发现Python读写Excel文件还是很方便的!
/python/blob/master/data/sheet%E5%90%88%E5%B9%B6.xls)
df.to_csv('../data/sheet合并.csv',index=False) df.to_excel('../data/sheet合并.xls',index=True)
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要介绍了Python连接数据库使用matplotlib画柱形图,文章通过实例展开对主题的相关介绍。具有一定的知识参考价值性,感兴趣的小伙伴可以参考一下
这篇文章主要介绍了python流程控制,文章主要根据python流程控制的相关资料展开全文内容,具有一定的参考解释,需要的小伙伴可以参考一下,希望对你有所帮助
这篇文章主要介绍了关于python中range()的参数问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
这篇文章主要介绍了用python制作北上广深——地铁线路动态图,文中的示例代码讲解详细,对我们的工作或学习都有一定的价值,感兴趣的同学可以学习一下
这篇文章主要介绍了python graphviz画图详情,文章围绕graphviz画图的相关资料展开内容,并附有官方安装链接,需要的小伙伴可以参考一下,洗碗给对你有所帮助
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008