其实我觉得很有必要讲述这个文章,用Python进行数据处理的第一步,就是数据的读取。其实在进行数据读取的时候,我们可以做很多事儿。鉴于read_excel()函数和read_csv()函数,在参数上面有很多相通点,因此我就以read_excel()函数为例,进行详细的说明。
# 下面这两个读取方式等同。
#df2 = pd.read_excel("readexcel.xlsx",sheet_name=0)
df2 = pd.read_excel("readexcel.xlsx",sheet_name="Sheet1")
df2
df2 = pd.read_excel("readexcel.xlsx",sheet_name=[0,1])
df2
结果如下:
接着,我们可以使用键值对的方式,获取每个sheet表中的数据。
注:关于sheet_name=None效果同上,只不过会返回所有的sheet表中的数据。
df3 = pd.read_excel("header.xlsx",header=None)
df3
df3 = pd.read_excel("header.xlsx",sheet_name=2,header=1)
df3
df3 = pd.read_excel("header.xlsx",sheet_name=3,header=[0,1],index_col=0)
df3
结果如下:
注意:上述用到了一个index_col参数,这个参数用于指定作为行索引的列,我就不详细举例了,看看下图。
df4 = pd.read_excel("usecols.xlsx",usecols=None) # 默认
df4
df4 = pd.read_excel("usecols.xlsx",usecols="A,C")
df4
df4 = pd.read_excel("usecols.xlsx",usecols="A,C:D")
df4
df4 = pd.read_excel("usecols.xlsx",usecols=[0,2])
df4
这种方式照说是没有任何问题的,但是在我这边运行总是无结果,我很纳闷,大家可以下去试试。
names = ["月份","语文","英语"]
df6 = pd.read_excel("names.xlsx",header=None,names=names)
df6
df7 = pd.read_excel("dtype.xlsx")
df7.dtypes
------------------------------------------------------
df7 = pd.read_excel("dtype.xlsx",dtype={"年龄":"str"})
df7.dtypes
df8 = pd.read_excel("parse_dates",index_col=2,parse_dates=True)
df8.index
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"])
#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
df8 = pd.read_excel("parse_dates.xlsx",sheet_name="Sheet2",parse_dates={"日期":[1,2,3]})
df8
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
df10 = pd.read_excel("na_values.xlsx",na_values=" ")
df10
df10 = pd.read_excel("na_values.xlsx",na_values=["a","0"])
df10
# 只替换某一列中的某些值为NaN
df10 = pd.read_excel("na_values.xlsx",na_values={"列2":["0"," "]})
df10
df11 = pd.read_excel("converters.xlsx",
converters={"地址":lambda x: "中国"+x,"工资":lambda x: x + 1000})
df11