1.问题

在python中,读写excel数据方法很多,比如xlrd、xlwt和openpyxl,实际上限制比较多,不是很方便。比如openpyxl也不支持csv格式。有没有更好的方法?

2.方案

更好的方法可以使用pandas,虽然pandas不是专门处理excel数据,但处理excel数据确实很方便。

本文使用excel的数据来自网络,数据内容如下:

2.1.安装

使用pip进行安装。

pip3 install pandas

导入pandas:

import pandas as pd

下文使用pd进行pandas的操作。

2.2.读写文件

读取文件,比如excel,csv文件

# df是pandas.core.frame.DataFrame类型
df = pd.read_excel('./data/2020-suv.xlsx')# read_csv可以指定分割符,编码方式等
df2 = pd.read_csv('./data/2020-suv.csv')

写入文件:

df.to_excel('./data/2020-suv-new.xlsx')
df.to_csv('./data/2020-suv-new.csv')

2.3.数据操作

  • 获取列名
all_cols = df.columns
print(all_cols)# 输出,df.columns并非list类型
Index(['销量排名', '车系', '官方价', '从属品牌', '1-12月销量'], dtype='object')# df.columns并非list类型,可以转化list
cols = list(df.columns)
  • 获取列数据
col_data = df[u'车系']
mul_col_data = df[ [u'车系', u'1-12月销量'] ]
  • 获取行数据
row_data = df.iloc[row_index]
  • 获取所有行数据
all_data = df.values
  • 切片获取多行数据
mul_row_data = df.iloc[2:4]
  • 获取单元个数据
cell_data = df.iloc[row_index][col_index]

2.4.数据筛选

Excel数据筛选比较实用,用pandas同样可以,并且筛选代码保存后,下次可以直接使用。

  • 某个字段包含指定值
# 包含一个值,na表示是否需要填充,case表示是否区分大小写,更强大的是contains还支持正则表达式
sub_df = df[ df[col_name].str.contains('key1', na=False, case=False) ]# 包含多个值,多次调用即可
sub_df1 = df[ df[col_name].str.contains('key1', na=False, case=False) ]
sub_df2 = sub_df1[ sub_df1[col_name].str.contains('key2', na=False, case=False) ]# 包含多个值(或)
sub_df = df[ df[col_name].str.contains('key1|key2|key3', na=False, case=False) ]# 不包含,也就是非的过滤
sub_df = df[ ~df[col_name].str.contains('key1', na=False, case=False) ]

上述操作,都假设字段类型是字符串类型,不然会抛异常。可以通过以下的方法,可以判断字段是否是字符类型:

pd.api.types.is_string_dtype(df[u'车系'])# 其他类型也有类似的函数,可以用dir查看有哪些类型判断
print(dir(pd.api.types))# 可以通过dtypes查看字段的类型
pd.dtypes
pd[u'1-12月销量'].dtypes
  • 条件过滤
# 大于
df[ df['1-12月销量'] > 50000 ] .values# 相等
df[ df['1-12月销量'] == 50000 ] .values

2.5.数据写入

  • 添加一行数据:
# 插在最后,row_datas是list
df.loc[len(df.index)] = row_datas
  • 插入一列数据
# 在指定列前面插上一列数据
df.insert( col_index, col_name, col_datas, True)
  • 更新某个单元值
df.iloc[row][col] = u'new-data'

2.6.数据删除

  • 删除一列
df2 = df.drop('官方价', axis=1, inplace=False)
print(df2)# 输出
销量排名           车系   从属品牌  1-12月销量
0       1         哈弗H6     哈弗   376864
1       2       本田CR-V     本田   249983
2       3           博越   吉利汽车   240811
3       4          途观L     大众   178574
4       5  长安CS75 PLUS   长安汽车   266824
..    ...          ...    ...      ...
282   283      北汽新能源EX  北汽新能源      879
283   284        奔腾X40     奔腾    20412
284   285    标致2008新能源     标致       37
285   286       猎豹CS10   猎豹汽车       14
286   287         森雅R7     一汽        1[287 rows x 4 columns]
  • 删除一行
df3 = df.drop(2, axis=0, inplace=False)
print(df3)# 输出销量排名           车系           官方价   从属品牌  1-12月销量
0       1         哈弗H6   9.80-15.49万     哈弗   376864
1       2       本田CR-V  16.98-27.68万     本田   249983
3       4          途观L  21.58-28.58万     大众   178574
4       5  长安CS75 PLUS  10.69-15.49万   长安汽车   266824
5       6       本田XR-V  12.79-17.59万     本田   168272
..    ...          ...           ...    ...      ...
282   283      北汽新能源EX  18.39-20.29万  北汽新能源      879
283   284        奔腾X40          暂无报价     奔腾    20412
284   285    标致2008新能源  16.60-18.80万     标致       37
285   286       猎豹CS10   7.98-11.98万   猎豹汽车       14
286   287         森雅R7   6.69-10.69万     一汽        1[286 rows x 5 columns]

3.讨论

pandas库用于大数据分析和AI,库本身比较复杂,很多功能未必用得上,日常使用可以简单的封装,能够读、写、搜索excel或csv数据,pandas比起专门操作excel的库要好用得多,简单封装一下即可。详细的使用说明,可以参见pandas官方文档。
https://pandas.pydata.org/docs/user_guide/index.html#user-guide

Python学习:如何使用pandas分析excel数据相关推荐

  1. 【Python学习】使用pandas和matplotlib分析1949-2016年中国各省市历年GDP数据

    [Python学习]使用pandas和matplotlib分析1949-2016年中国各省市历年GDP数据 导入包 读取数据 设置颜色列表 绘图分析 导入包 由于我是在jupyter notebook ...

  2. 用python分析excel数据_Python3分析Excel数据

    3.1 内省Excel工作薄 使用xlrd和xlwt扩展包,确定工作簿中工作表的数量.名称和每个工作表中行列的数量. 1excel_introspect_workbook.py #!/usr/bin/ ...

  3. python在excel中的应用-Python利用pandas处理Excel数据的应用详解

    最近迷上了高效处理数据的pandas,其实这个是用来做数据分析的,如果你是做大数据分析和测试的,那么这个是非常的有用的!!但是其实我们平时在做自动化测试的时候,如果涉及到数据的读取和存储,那么而利用p ...

  4. python与excel的应用-Python利用pandas处理Excel数据的应用

    最近迷上了高效处理数据的pandas,其实这个是用来做数据分析的,如果你是做大数据分析和测试的,那么这个是非常的有用的!!但是其实我们平时在做自动化测试的时候,如果涉及到数据的读取和存储,那么而利用p ...

  5. python处理excel表格-Python利用pandas处理Excel数据的应用

    最近迷上了高效处理数据的pandas,其实这个是用来做数据分析的,如果你是做大数据分析和测试的,那么这个是非常的有用的!!但是其实我们平时在做自动化测试的时候,如果涉及到数据的读取和存储,那么而利用p ...

  6. [转载] Python利用pandas处理Excel数据的应用

    参考链接: Python | Pandas数据比较与选择 最近迷上了高效处理数据的pandas,其实这个是用来做数据分析的,如果你是做大数据分析和测试的,那么这个是非常的有用的!!但是其实我们平时在做 ...

  7. python pandas excel数据处理_Python利用pandas处理Excel数据的应用

    python如何将列表导出为csv文件 import pandas as pd list=[[1,2,3],[4,5,6],[7,8,9]] column=['column1','column2',' ...

  8. python pandas处理excel 统计数据_python使用pandas处理excel数据

    使用Python Pandas库读取excel文件(.xlsx, .xls). 使用pandas的 read_excel()方法来读取excel数据,可以读取第一个sheet,指定的sheet,多个s ...

  9. python使用pandas处理excel数据

    使用Python Pandas库读取excel文件(.xlsx, .xls). 使用pandas的 read_excel()方法来读取excel数据,可以读取第一个sheet,指定的sheet,多个s ...

最新文章

  1. 独家 | CIKM AnalytiCup 2017冠军团队获胜经验分享(附PPT视频)
  2. 2018焦作网络赛-E- Jiu Yuan Wants to Eat
  3. cdh 添加jar包_使用maven下载cdh版本的大数据jar包
  4. 使用 BOOST_PROTO_DEFINE_OPERATORS 使用非原型类型 std::vector<> 对表达式进行原型化的示例
  5. 让不支持h5新标签的浏览器支持新标签
  6. Scrapy 和 scrapy-redis的区别
  7. Mac 配置jupyter notebook 扩展 Nbextensions
  8. 输入法 java_使用 Utf7ime 输入法实现中文输入 Windows+Java 平台(完整步骤版)
  9. SAP License:SD与COPA集成
  10. JavaScript事件 以及和jQuery中事件使用对比
  11. 双“11”搞促销?用贪心算法盘它
  12. 滴滴否认上海团队解散;雄安超前布局 5G;小米拆分独立品牌 | 极客头条
  13. android上ps/grep/kill组合杀死mediaserver/system_server
  14. 怎么使用水经注万能地图下载器制作百度个性化建筑地图
  15. android SoundPool例子,Android SoundPool即时音效的使用Demo
  16. 项目管理前话001——商业模式画布
  17. 高等数学张宇18讲 第十一讲 二重积分
  18. linux命令scp(复制文件和目录)详解及cp和scp命令的使用方法
  19. DirectX和OPenGL 与 UE4、U3D、Webgl(ThreeJS)的关系
  20. cad剖切线的快捷键_Auto CAD2016剖面线快捷键是什么呢??

热门文章

  1. 经典的就要转载:另类DLL注入法 ,mian杀
  2. 【历史上的今天】10 月 25 日:Windows XP 诞生;任正非出生;图灵奖编程语言先驱诞生
  3. 单细胞基因可视化之UMAP图修饰
  4. 无限制高速下载百度网盘大文件方法
  5. java基础巩固-宇宙第一AiYWM:为了维持生计,架构知识+分布式微服务+高并发高可用高性能知识序幕就此拉开(三:注册中心、补充CAP定理、BASE 理论)~整起
  6. PMC荣获华为质量专项奖
  7. Python简单实现邂逅在迷宫无限十连自动抽卡并根据金卡数量停止程序
  8. 记录vue的双向绑定原理及实现
  9. js 正则 字母数字下划线,数字不能在首位
  10. 【开源项目学习】源码剖析,学习仿网易云音乐app代码