本文大纲

我觉得很有必要讲述这个文章,进行数据处理的第一步就是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"]}
#  只替换某一列中的某些值为NaNdf10 = 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

结果如下:


------end------

不读取nan行_一个参数一个Excel表,让你玩转Pandas中read_excel()表格读取!相关推荐

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

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

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

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

  3. ​一个参数一张Excel表,玩转Pandas的read_excel()表格读取

    作者 | 黄伟呢 来源 | 数据分析与统计学之美 我觉得很有必要讲述这个文章,进行数据处理的第一步就是Python数据读取.但是你可能没想到,在进行数据读取的同时,我们其实可以配合相关参数做很多事儿, ...

  4. python读取第二行_使用Python操作Excel(二):读取数据表

    上一节我们提到,使用openpyxl可以方便的对数据表进行操作,例如:抽象Excel数据并存入数据库 将数据库数据导出到Excel 给一个已存在的数据表追加信息 我们还介绍了一些Excel的基本术语, ...

  5. Pandas中read_excel函数参数使用详解+实例代码

    目录 前言 一.数据展示 1.io 2.sheet_name 3.header 4.names 5.index_col 6.usecols 7.squeeze 8.dtype 9.engine 10. ...

  6. 读取指定文件夹里多个excel表,并将所有excel表数据整合到一个excel中

    1.找出指定文件夹里的所有文件 #-*- encoding: utf-8 -*-# 找出指定文件夹里的所有文件 import osfilePath = 'C:\\Users\\lzk\\Desktop ...

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

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

  8. python使用xlrd读取xlsx文件_$ 用python处理Excel文档(1)——用xlrd模块读取xls/xlsx文档...

    本文主要介绍xlrd模块读取Excel文档的基本用法,并以一个GDP数据的文档为例来进行操作. 1. 准备工作: 1. 安装xlrd:pip install xlrd 2. 准备数据集:从网上找到的1 ...

  9. 单元格内容分列多行_『如何将excel单个表格里的多行数据分列』

    excel中怎样分列不规律的数据 1.我们打开 Excel 表的数据方式, 我们可以看到于歌曲的和对歌手数响应, 那么如果我们想把这个道路数据分成两个数据. 2.首先用鼠标点击列数据顶部, 列数据称为 ...

  10. excel导入mysql命令行_使用命令行将Excel数据表导入Mysql中的方法小结

    从Excel数据表导入MySQL,已经做过好几次了,但每次都会碰到各种问题:invalid utf8 character string, data too long, ...,浪费了不少时间 为了提高 ...

最新文章

  1. centos7 无法启动网络(service network restart)错误解决办法
  2. 【机器视觉】 dev_update_window算子
  3. CFtpFileFind FindFile卡住的问题
  4. html5游戏制作入门系列教程(三)
  5. 关于node中的板块问题
  6. 将商品金额小写转换成大写
  7. Gambit 5.调试
  8. 使用pdfbox将多个pdf合成一个pdf
  9. 智能优化算法:灰狼优化算法-附代码
  10. Linux内核原理-pid namespace
  11. SpringBoot基础-refresh方法解析
  12. 如何做一个企业网站制作
  13. 云服务器系统种类,云服务器系统种类
  14. 构建开源产业生态,加速落地云原生,骞云加入开源GitOps产业联盟
  15. 三、Hive数据仓库应用之Hive数据操作语言(超详细步骤指导操作,WIN10,VMware Workstation 15.5 PRO,CentOS-6.7)
  16. git 删除远程仓库命令
  17. rk3399 Android休眠/唤醒分析(2)
  18. uwsgi listen配置
  19. C语言编译、链接和运行详解
  20. OA软件的核心:工作流引擎

热门文章

  1. [译] 你的站点如你所想的移动友好吗?
  2. 《VMware Virtual SAN权威指南》一2.2.2 VSAN Ready Nodes
  3. MyBatis Review——多对多映射
  4. 钉钉机器人智能提醒_利用钉钉机器人和语雀提高协同办公效率
  5. java 接口返回不带双引号_Java入门:基础知识
  6. autoit选中图标无反应_ps图标教学,使用小技巧。
  7. python常见报错异常大全,根据异常找出根本问题,一键解决,建议收藏
  8. python unrar问题_Python提取/unrar RAR文件错误
  9. python运维脚本部署jdk_Python+PyDev+Jdk+Eclipse开发环境部署
  10. linux服务器备份,Linux服务器上如何备份