作者 | 黄伟呢

来源 | 数据分析与统计学之美

我觉得很有必要讲述这个文章,进行数据处理的第一步就是Python数据读取。但是你可能没想到,在进行数据读取的同时,我们其实可以配合相关参数做很多事儿,这对于后续的数据处理都是极其有帮助。

read_excel()函数和read_csv()函数,在参数上面有很多相同点,因此我就以read_excel()函数为例,进行详细的说明。

1)sheet_name参数

  • 含义:选择要读取的sheet表;

  • sheet_name=0表示默认读取第一个sheet表,等同于sheet_name=“sheet名称”;

  • sheet_name=[“sheet名”,0]会返回一个字典,然后可以利用键获取每一个sheet表中的数据;

  • sheet_name=None也会返回一个字典,但是会返回全部的sheet表;

① sheet_name=0和sheet_name="Sheet1"
# 下面这两个读取方式等同。
#df2 = pd.read_excel("readexcel.xlsx",sheet_name=0)
df2 = pd.read_excel("readexcel.xlsx",sheet_name="Sheet1")
df2

结果如下:

② sheet_name=[“sheet名”,0]
df2 = pd.read_excel("readexcel.xlsx",sheet_name=[0,1])
df2

结果如下:

接着,我们可以使用键值对的方式,获取每个sheet表中的数据。

注:关于sheet_name=None效果同上,只不过会返回所有的sheet表中的数据。

2)header参数

  • 含义:指定某一行作为表头;

  • header=None专门针对没有表头的表,这也是默认值;

  • header=1指定第一行作为表头;

  • header=[]主要针对复合表头的情况;

① header=None
df3 = pd.read_excel("header.xlsx",header=None)
df3

结果如下:

②  header=1
df3 = pd.read_excel("header.xlsx",sheet_name=2,header=1)
df3

结果如下:

③ header=[]
df3 = pd.read_excel("header.xlsx",sheet_name=3,header=[0,1],index_col=0)
df3

结果如下:

注意:上述用到了一个index_col参数,这个参数用于指定作为行索引的列,我就不详细举例了,看看下图。

3)usecols参数

  • 含义:选择读取一张表中的指定列;

  • usecols=None也是默认情况,表示读取所有列;

  • usecols=[A,C]表示只选取A列和C列。usecols=[A,C:E]表示选择A列,C列、D列和E列;

  • usecols=[0,2]表示只选择第一列和第三列;

  • usecols=["列名1","列名2"...]这也是推荐使用的一种写法;

① usecols=None
df4 = pd.read_excel("usecols.xlsx",usecols=None) # 默认
df4

结果如下:

② usecols=[A,C]
df4 = pd.read_excel("usecols.xlsx",usecols="A,C")
df4

结果如下:

③ usecols=[A,C:D]
df4 = pd.read_excel("usecols.xlsx",usecols="A,C:D")
df4

结果如下:

④ usecols=[0,2]
df4 = pd.read_excel("usecols.xlsx",usecols=[0,2])
df4

结果如下:

⑤ usecols=["列名1","列名2"...]

这种方式照说是没有任何问题的,但是在我这边运行总是无结果,我很纳闷,大家可以下去试试。

4)names参数

  • 含义:如果表中没有表头,可以用这个参数添加一个标题。如果表中有表头,可以用这个参数修改标题。

names = ["月份","语文","英语"]
df6 = pd.read_excel("names.xlsx",header=None,names=names)
df6

结果如下:

5)dtype参数

  • 含义:读取数据时,设置每一列的数据类型(重要);

  • dtype={}传入一个字典,类似于{"列名":"类型"};

df7 = pd.read_excel("dtype.xlsx")
df7.dtypes
------------------------------------------------------
df7 = pd.read_excel("dtype.xlsx",dtype={"年龄":"str"})
df7.dtypes

结果如下:

6)parse_dates参数

  • 含义:指定将哪些列,解析为日期格式;

  • parse_dates=True是专门用于将行索引,解析为日期格式;

  • parse_dates=[0,1,2,3,4]和parse_dates=["列名1","列名2","列名3","列名4"],都是将指定列一起解析为日期格式;

  • parse_dates=[[1,2,3]]和parse_dates=[["年","月","日"]],都是将多个列,解析为单个日期列;

  • parse_dates={"日期":[1,2,3]}不仅将多个日期列解析为单个日期列,同时还为这一列命名;

① parse_dates=True
df8 = pd.read_excel("parse_dates",index_col=2,parse_dates=True)
df8.index

结果如下:

② parse_dates=[0,1]和parse_dates=["列名1","列名2"]
df8 = pd.read_excel("parse_dates",parse_dates=[0,1,2,3,4])
df8.dtypes
# 这个代码效果同上
df8 = pd.read_excel("parse_dates.xlsx",parse_dates=["数值日期1","文本日期2","文本日期3","文本日期4","文本日期5"])

结果如下:

③ parse_dates=[[1,2,3]]和parse_dates=[["年","月","日"]]
#df8 = pd.read_excel("parse_dates.xlsx",sheet_name="Sheet2",parse_dates=[["年","月","日"]])
df8 = pd.read_excel("parse_dates.xlsx",sheet_name="Sheet2",parse_dates=[[1,2,3]])
df8

结果如下:

④ parse_dates={"日期":[1,2,3]}
df8 = pd.read_excel("parse_dates.xlsx",sheet_name="Sheet2",parse_dates={"日期":[1,2,3]})
df8

结果如下:

7)date_parser参数
  • 含义:利用lambda函数,将某个字符串列,解析为日期格式;

  • 一般是配合parse_dates参数,一起使用;

df9 = pd.read_excel("date_parser.xlsx",parse_dates=[1],date_parser=lambda x: pd.to_datetime(x,format="%Y年%m月%d"))
print(df9.dtypes)
df9

结果如下:

8)na_values参数

  • 含义:用于将某些特定的值,解析为NaN值,然后便于我们后面做缺失值的处理;

  • na_values=”值1“表示将所有数据中值1全部替换为NaN;

  • na_values=[”值1“,"值2"]表示将所有数据中值1、值2全部替换为NaN;

  • na_values={"列1":[”值1“,"值2"]}表示将第一列中所有的值1、值2全部替换为NaN;

① na_values=”值1“
df10 = pd.read_excel("na_values.xlsx",na_values=" ")
df10

结果如下:

② na_values=[”值1“,"值2"]
df10 = pd.read_excel("na_values.xlsx",na_values=["a","0"])
df10

结果如下:

③ na_values={"列1":[”值1“,"值2"]}
#  只替换某一列中的某些值为NaN
df10 = pd.read_excel("na_values.xlsx",na_values={"列2":["0"," "]})
df10

结果如下:

9)converters参数
  • 含义:对某一列使用Lambda函数,进行某种运算;

  • 例如:converters={"工资":lambda x: x + 1000};

df11 = pd.read_excel("converters.xlsx",converters={"地址":lambda x: "中国"+x,"工资":lambda x: x + 1000})
df11

结果如下:

推荐阅读

  • 算法实现太难了?机器学习也需要开源软件

  • TikTok算法背后是抖音用户数据?想多了

  • 图解Transformer,读完这篇就够了

  • 马小峰:金融科技界的区块链博士

  • 2019年中国IaaS公有云市场排名及份额出炉

​一个参数一张Excel表,玩转Pandas的read_excel()表格读取相关推荐

  1. 一个参数一个Excel表,让你玩转Pandas中read_excel()表格读取!

    本文大纲 我觉得很有必要讲述这个文章,进行数据处理的第一步就是Python数据读取.但是你可能没想到,在进行数据读取的同时,我们其实可以配合相关参数做很多事儿,这对于后续的数据处理都是极其有帮助. r ...

  2. pandas 读取某一单元格的值_一个参数一个Excel表,让你玩转Pandas中read_excel()表格读取!...

    建议文末获取练习素材 一个个操作一遍 本文大纲 我觉得很有必要讲述这个文章,进行数据处理的第一步就是Python数据读取.但是你可能没想到,在进行数据读取的同时,我们其实可以配合相关参数做很多事儿,这 ...

  3. Java对比两张Excel表的数据,java对比两个excel或者一张excel和数据库的一张表的数据是否相同,两张excel表格匹配相同的数据库...

    excel自动从数据库匹配相应的数据 vlookup函数:vlookup(lookup_value,table_array,col_index_num,[range_lookup]) 第一个:look ...

  4. python excel整合_如何整合100张excel表到一张excel表

    实际工作中经常会有整合多张excel表的需求,比如,对几张表合并时,我们有时候需要知道哪些原始数据是来自哪张表,例如,三张表是来自三个不同的人,我们可以把每张表用人名命名,这样就可以知道数据来自谁. ...

  5. python比较excel表格内容并提取_利用python提取多张excel表数据并汇总到同一张新表中...

    接上篇文章<如何用python实现excel中的vlookup功能?>,上篇说到,最近我在做一个小项目,也是用python操作excel解决财务审计工作上的一些问题,以便提高工作效率及其准 ...

  6. Python提取多张excel表上的数据,合并汇总到一张新表

    本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理 以下文章来源于财会学习联盟,作者:我是刀哥啊 私信回复"资料" ...

  7. 0.进校的第一张Excel表:“住宿分布表” ——《Excel“智能化”之路》 系列文章

    <Excel"智能化"之路> 系列文章 系列目录    0.进校的第一张Excel表:"住宿分布表" 系列前言    转眼间就大二了,感觉自己还没学 ...

  8. pandas使用read_excel函数读取excel表格数据为dataframe、设置sheet_name参数为表单索引位置列表则读取多个表单的数据并返回dataframe字典

    pandas使用read_excel函数读取excel表格数据为dataframe.使用sheet_name参数指定读取excel表格中指定的sheet表单.设置sheet_name参数为表单索引位置 ...

  9. 多张excel表合并汇总怎么做?

    今天跟大家分享一下多张excel表合并汇总怎么做? 1.打开演示文件,要求快速完成多个工作表数据汇总 2.首先点击下图选项 3.然后我们选中表格数据单元格区域 4.点击[汇总拆分],然后鼠标选择[汇总 ...

最新文章

  1. BZOJ 2004 [Hnoi2010]Bus 公交线路
  2. Android View篇之自定义验证码输入框
  3. 怎么把向上滑动取消_美瞳滑片是什么意思?为什么会滑片?怎么解决?
  4. Qt Creator设置Qbs
  5. 【机器学习】高斯判别分析
  6. 【VS开发】模态对话框和非模态对话框
  7. 六、jQuery 中的 AJAX 跨域问题
  8. 在VC中使用ADO开发数据库应用程序
  9. 紧急通知!不要在MySQL中使用UTF-8编码!!!
  10. GIT插件EGIT使用手册
  11. 云计算技术简述及发展分析
  12. 心理们-位大师的50本书
  13. EXCEL电子档色环电阻计算器
  14. Mac下nginx配置虚拟主机,访问报错502
  15. 嵌入式开发要学多久?要学哪些课程
  16. xp用户未授予用户在此计算机,未授予用户在此计算机上的请求登录类型的解决方法 win7XP共享打印机完美解决教程...
  17. 一文带你熟悉android的smali语法一
  18. [置顶] LED办公楼宇照明节能方案及城市夜景照明节能方案
  19. Kernel panic - not syncing
  20. springboot配置多源数据库

热门文章

  1. iptables如何开放被动模式的FTP服务
  2. redis入门(03)redis的配置
  3. js调用ios的方法
  4. Expect自动化控制简单介绍
  5. JS+CSS控制左右切换鼠标可控的无缝图片滚动代码
  6. Shell脚本读取命令行参数
  7. 如何理解导远技术手册
  8. Python中的对象,类,super()函数
  9. 优先级队列(小顶堆)的dijkstra算法
  10. 自己设计大学排名-数据库实践