pandas读取excel数据是什么格式(一个参数一张Excel表)(1)

pandas读取excel数据是什么格式(一个参数一张Excel表)(2)

作者 | 黄伟呢

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

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

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

pandas读取excel数据是什么格式(一个参数一张Excel表)(3)

1)sheet_name参数

① sheet_name=0和sheet_name="Sheet1"

# 下面这两个读取方式等同。

② sheet_name=[“sheet名”,0]

df2 = pd.read_excel("readexcel.xlsx",sheet_name=[0,1])

df2

结果如下:

pandas读取excel数据是什么格式(一个参数一张Excel表)(4)

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

pandas读取excel数据是什么格式(一个参数一张Excel表)(5)

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

2)header参数

① header=None

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

df3

结果如下:

pandas读取excel数据是什么格式(一个参数一张Excel表)(6)

② header=1

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

df3

结果如下:

pandas读取excel数据是什么格式(一个参数一张Excel表)(7)

③ header=

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

df3

结果如下:

pandas读取excel数据是什么格式(一个参数一张Excel表)(8)

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

pandas读取excel数据是什么格式(一个参数一张Excel表)(9)

3)usecols参数

① usecols=None

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

df4

结果如下:

pandas读取excel数据是什么格式(一个参数一张Excel表)(10)

② usecols=[A,C]

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

df4

结果如下:

pandas读取excel数据是什么格式(一个参数一张Excel表)(11)

③ usecols=[A,C:D]

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

df4

结果如下:

pandas读取excel数据是什么格式(一个参数一张Excel表)(12)

④ usecols=[0,2]

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

df4

结果如下:

pandas读取excel数据是什么格式(一个参数一张Excel表)(13)

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

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

4)names参数

names = ["月份","语文","英语"]

df6 = pd.read_excel("names.xlsx",header=None,names=names)

df6

结果如下:

pandas读取excel数据是什么格式(一个参数一张Excel表)(14)

5)dtype参数

df7 = pd.read_excel("dtype.xlsx")

df7.dtypes

------------------------------------------------------

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

df7.dtypes

结果如下:

pandas读取excel数据是什么格式(一个参数一张Excel表)(15)

6)parse_dates参数

① parse_dates=True

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

df8.index

结果如下:

pandas读取excel数据是什么格式(一个参数一张Excel表)(16)

② 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"])

结果如下:

pandas读取excel数据是什么格式(一个参数一张Excel表)(17)

③ 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

结果如下:

pandas读取excel数据是什么格式(一个参数一张Excel表)(18)

④ parse_dates={"日期":[1,2,3]}

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

df8

结果如下:

pandas读取excel数据是什么格式(一个参数一张Excel表)(19)

7)date_parser参数

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

结果如下:

pandas读取excel数据是什么格式(一个参数一张Excel表)(20)

8)na_values参数

① na_values=”值1“

df10 = pd.read_excel("na_values.xlsx",na_values=" ")

df10

结果如下:

pandas读取excel数据是什么格式(一个参数一张Excel表)(21)

② na_values=[”值1“,"值2"]

df10 = pd.read_excel("na_values.xlsx",na_values=["a","0"])

df10

结果如下:

pandas读取excel数据是什么格式(一个参数一张Excel表)(22)

③ na_values={"列1":[”值1“,"值2"]}

# 只替换某一列中的某些值为NaN

df10 = pd.read_excel("na_values.xlsx",na_values={"列2":["0"," "]})

df10

结果如下:

pandas读取excel数据是什么格式(一个参数一张Excel表)(23)

9)converters参数

df11 = pd.read_excel("converters.xlsx",

converters={"地址":lambda x: "中国" x,"工资":lambda x: x 1000})

df11

结果如下:

pandas读取excel数据是什么格式(一个参数一张Excel表)(24)

pandas读取excel数据是什么格式(一个参数一张Excel表)(25)

,