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

Posted 黄至尊qwe

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了一个参数一个xlsx表,让你玩转Pandas中read_excel()表格读取!相关的知识,希望对你有一定的参考价值。


本文大纲

其实我觉得很有必要讲述这个文章,用Python进行数据处理的第一步,就是数据的读取。其实在进行数据读取的时候,我们可以做很多事儿。鉴于read_excel()函数和read_csv()函数,在参数上面有很多相通点,因此我就以read_excel()函数为例,进行详细的说明。

一个参数一个xlsx表,让你玩转Pandas中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")

结果如下:

一个参数一个xlsx表,让你玩转Pandas中read_excel()表格读取!_数据_02

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

结果如下:

一个参数一个xlsx表,让你玩转Pandas中read_excel()表格读取!_读取数据_03


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

一个参数一个xlsx表,让你玩转Pandas中read_excel()表格读取!_读取数据_04


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

2)header参数

  • 含义:指定某一行作为表头;
  • header=None准们针对没有表头的表,这也是默认值;
  • header=1指定第一行作为表头;
  • header=[]主要针对复合表头的情况;
① header=None
df3 = pd.read_excel("header.xlsx",header=None)

结果如下:

一个参数一个xlsx表,让你玩转Pandas中read_excel()表格读取!_数据_05

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

结果如下:

一个参数一个xlsx表,让你玩转Pandas中read_excel()表格读取!_数据_06

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

结果如下:

一个参数一个xlsx表,让你玩转Pandas中read_excel()表格读取!_读取数据_07


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

一个参数一个xlsx表,让你玩转Pandas中read_excel()表格读取!_数据_08

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) # 默认

结果如下:

一个参数一个xlsx表,让你玩转Pandas中read_excel()表格读取!_读取数据_09

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

结果如下:

一个参数一个xlsx表,让你玩转Pandas中read_excel()表格读取!_日期格式_10

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

结果如下:

一个参数一个xlsx表,让你玩转Pandas中read_excel()表格读取!_日期格式_11

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

结果如下:

一个参数一个xlsx表,让你玩转Pandas中read_excel()表格读取!_日期格式_12

⑤ usecols=[“列名1”,“列名2”…]

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

4)names参数

  • 含义:如果表中没有表头,可以用这个参数添加一个标题。如果表中有表头,可以用这个参数修改标题。
names = ["月份","语文","英语"]
df6 = pd.read_excel("names.xlsx",header=None,names=names)

结果如下:

一个参数一个xlsx表,让你玩转Pandas中read_excel()表格读取!_日期格式_13

5)dtype参数

  • 含义:读取数据时,设置每一列的数据类型(重要);
  • dtype=传入一个字典,类似于“列名”:“类型”;
df7 = pd.read_excel("dtype.xlsx")
df7.dtypes
------------------------------------------------------
df7 = pd.read_excel("dtype.xlsx",dtype="年龄":"str")
df7.dtypes

结果如下:

一个参数一个xlsx表,让你玩转Pandas中read_excel()表格读取!_数据_14

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

结果如下:

一个参数一个xlsx表,让你玩转Pandas中read_excel()表格读取!_读取数据_15

② parse_dates=[0,1,2,3,4]和parse_dates=[“列名1”,“列名2”,“列名3”,“列名4”]
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"])

结果如下:

一个参数一个xlsx表,让你玩转Pandas中read_excel()表格读取!_数据_16

③ 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]])

结果如下:

一个参数一个xlsx表,让你玩转Pandas中read_excel()表格读取!_日期格式_17

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

结果如下:

一个参数一个xlsx表,让你玩转Pandas中read_excel()表格读取!_数据_18

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)

结果如下:

一个参数一个xlsx表,让你玩转Pandas中read_excel()表格读取!_读取数据_19

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=" ")

结果如下:

一个参数一个xlsx表,让你玩转Pandas中read_excel()表格读取!_日期格式_20

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

结果如下:

一个参数一个xlsx表,让你玩转Pandas中read_excel()表格读取!_数据_21

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

结果如下:

一个参数一个xlsx表,让你玩转Pandas中read_excel()表格读取!_数据_22

9)converters参数
  • 含义:对某一列使用Lambda函数,进行某种运算;
  • 例如:converters=“工资”:lambda x: x + 1000;
df11 = pd.read_excel("converters.xlsx",
converters="地址":lambda x: "中国"+x,"工资":lambda x: x + 1000)

结果如下:

一个参数一个xlsx表,让你玩转Pandas中read_excel()表格读取!_日期格式_23


以上是关于一个参数一个xlsx表,让你玩转Pandas中read_excel()表格读取!的主要内容,如果未能解决你的问题,请参考以下文章

一篇博文教你玩转pandas,轻松应付办公场景(机器学习基础)

python数据分析基础009 -利用pandas带你玩转excel表格(下篇)

python数据分析基础007 -利用pandas带你玩转excel表格(中上篇)

报名开启阿里云线下Workshop让你玩转ECS 快速搭建云上博客

python数据分析基础006 -利用pandas带你玩转excel表格(上篇)

带你玩转数据分析