像用excel一样用pandas
1 说明
- 预计需要15min阅读此教材;
- 本教材仅讲述如何查看excel数据,筛选,排序,查找替换数据,不涉及excel中复杂的图形绘制及样式修改。
2 假设
假设,已经存在一个test.xlsx文件,仅包含一个sheet,文件内容如下。
col1 | col2 |
---|---|
foo1 | bar1 |
foo2 | bar2 |
3 读取
3.1 读取excel
读取一个excel并赋值给df
import pandas as pd
df = pd.read_excel('foo.xlsx')
查看行列数
#法一
df.shape
# (2,2)
# m,n其中m为行数,n为列数
# 法二
df.info()
# <class 'pandas.core.frame.DataFrame'>
# RangeIndex: 2 entries, 0 to 1
# Data columns (total 2 columns):
# col1 fa 2 non-null object
# col2 fa 2 non-null object
# dtypes: object(2)
# memory usage: 112.0+ bytes
查看列名
df.columns
# Index(['col1', 'col2'], dtype='object')
说明:如果没有定义表头columns展示仅是索引名1,2,3
获取单元格值
如果了解单元格的行列值可以使用iloc方法获取单元格值。
df.iloc[m, n]
其中m为行数,n为列数,二者均从0开始索引。
查看行
可以使用标签,切片,标签矩阵等等获取行数。
# 查看单行
df.iloc[1] or df.loc['index']
# 查看多行
df.iloc[[1,2,3,4,8,9]]
# 查看前7行
df.iloc[:7]
# 或者
df.loc[:7]
python中切片是不算终止一个元素的,df.iloc取前n个元素是使用':n',而loc方法是计算终止元素的,取前n元素方法就变为df.loc[:n-1]
查看列
# 查看单列
df['col1']或者df.col1,,其中col1为列名。推荐使用df.col1
# 查看多列,过滤时传入一个列数组
df[['col1','col2']]
# 查看前7列,由于不清楚前7列名,使用[]选择较为困难,pandas提供iloc方法,支持切片选择。
# :意味着选择所有行,0:7意味着选择从1行到第7行
df.iloc[[: , 0:7]]
如果excel表格有列名且没有空格,pandas会默认为df增加一个同列名的字段
全表查看
pandas没有全表查看api,如果要全表查看需要自行编写代码:
# 由于DataFrame是采用列式存储,这里第一层循环使用列,第二层循环使用行。
for i in df.columns:
for j in df.index:
if df.loc[j, i] == 'bar2':
print('column name:',i,',row idx:',j)
4 表格操作
4.1 新增
插入新列
插入新列仅需添加一个新的值,并赋值一个Series对象即可。
df['newcolumn']= pd.Series([1,2])
插入新行
方法一:使用loc。
# 注意在插入时列必须匹配,不能有缺省列。
chipo.loc[chipo.shape[0]]={'col1':value}
方法二:使用append
newdf = pd.DataFrame({'col3':value})
# 插入一条记录
df = df.append(newdf, ignore_index=True)
4.2 修改
修改单元格的值
如果你知道修改单元格的行和列可以使用iloc方法:
# 行和列从0开始索引
df.iloc[m, n] = targetV
4.3 删除
DataFrame提供drop方法支持批量删除行和列。
drop(labels, axis=0, level=None, inplace=False, errors='raise')
# --axis为0时表示删除行,axis为1时表示删除列
参数解释,
# 删除第一和第三行
df.drop(label=[1,3])
# 删除名为item的列
df.drop(label=['item'], axis=1)
# 等价
df.drop(label='item', axis=1)
pandas仅支持按标签删除行列,不支持按行列值删除,这点与选择不同
5 过滤和排序
5.1 过滤
添加过滤条件,
df[df.col1=='Chicken Bowl']
如果在一个列中要选择多个值,Series对象有isin方法可以实现该功能
df[df.col1.isin('Chicken Bowl','huawei')]
多条件过滤
如果需要添加多个过滤条件可以使用,
df[(df.col1=='Chicken Bowl') & (df.col2==30)]
该方法返回值类型为DataFrame。
5.2 排序
DataFrame和Series都有sort_values方法,可按照某列数据做排序。排序方法返回的值依然为DataFrame。
df.sort_values(['column'])
//sort_values支持传入数组,所以可以指定多个排序字段
# or 使用Series方法
df.col1.sort_values()
设定排序顺序
//按降序排序
df.sort_values(['col1','col2'],ascending=False)
按列值排序
df.sort_index(axis=1, ascending=False)
单列排序会影响所有记录重新排序,而不是影响单独列。
6 保存文件
至此,你已学会如何读取文件,查看数据并操作excel值,现在需要将结果写回excel。DataFrame提供to系列方法实现写回。
df.to_excel('test.xlsx', sheet_name='Sheet1')
注意读取时使用pandas静态方法,写回则使用DataFrame的方法
引用
像用excel一样用pandas的更多相关文章
- 51-python3 pandas读写excel
转载自:https://blog.csdn.net/brink_compiling/article/details/76890198?locationNum=7&fps=1 0. 前言Pyth ...
- python pandas写入excel文件
pandas读取.写入csv数据非常方便,但是有时希望通过excel画个简单的图表看一下数据质量.变化趋势并保存,这时候csv格式的数据就略显不便,因此尝试直接将数据写入excel文件. pandas ...
- 数据可视化基础专题(二):Pandas基础(一) excel导入与导出
1.Excel 1.1 Excel导入 read_excel() pandas.read_excel(io, sheet_name=0, header=0, names=None, index_col ...
- 用python的pandas读取excel文件中的数据
一.读取Excel文件 使用pandas的read_excel()方法,可通过文件路径直接读取.注意到,在一个excel文件中有多个sheet,因此,对excel文件的读取实际上是读取指定文件.并 ...
- 【Python自动化Excel】pandas处理Excel数据的基本流程
这里所说的pandas并不是大熊猫,而是Python的第三方库.这个库能干嘛呢?它在Python数据分析领域可是无人不知.无人不晓的.可以说是Python世界中的Excel. pandas库处理数据相 ...
- python数据处理excel和pdf,并打包成exe
之前零散的用过一点python做数据处理,这次又遇到一个数据处理的小功能,因此,记录一下整个流程,方便以后查阅. 功能要求:读取excel,找指定的PDF文件的页数是否与excel中记录的一致 整个处 ...
- pandas库的学习笔记
Environment pandas 0.21.0 python 3.6 jupyter notebook 开始 习惯上,我们导入如下: import pandas as pd import nump ...
- Pandas 处理丢失数据
处理丢失数据 import pandas as pd from pandas import Series, DataFrame import numpy as np 有两种丢失数据: 1. None ...
- 13--Python入门--文件读写--CSV&Excel文件
EXCEL文件 import pandas as pd excel=pd.read_excel('read_excel.xlsx') print(excel) CSV文件 import pandas ...
随机推荐
- [POI2005]SAM-Toy Cars 贪心+堆
[POI2005]SAM-Toy Cars 题目:Jasio 是一个三岁的小男孩,他最喜欢玩玩具了,他有n 个不同的玩具,它们都被放在了很高的架子上所以Jasio 拿不到它们:为了让他的房间有足够的空 ...
- LiteOS-任务篇-源码分析-任务调度函数
目录 前言 笔录草稿 核心源码分析 osTaskSchedule函数源码分析 osPendSV函数源码分析 TaskSwitch函数源码分析 调度上层源码分析 osSchedule函数源码分析 LOS ...
- shell-整数测试多范例多生产案例举例
1. 整数测试举例范例1:整数条件测试举例 root@test-1 ~]# a1=10;a2=13 [root@test-1 ~]# echo $a1 $a2 10 13 [root@test-1 ~ ...
- java 的 callback
Java 本身没有回调这一说,但是面向对象可以模拟出来. 1. 回调接口对象 ICommand package com.git.Cmder; public interface ICommand { v ...
- 多测师讲解python _函数中参数__高级讲师肖sir
函数中讲解参数: 形参和实参的认识 函数无参数的调用 函数单个参数的调用 函数多个参数的调用 # #调试函数给默认参数传新值,则函数使用新值 # 注意:当多种参数同时出现在函数中,默认参数要放在最后的 ...
- 【CF1428D】Bouncing Boomerangs 题解
原题链接 题意简介 毒瘤大模拟 给你一张n*n的图,在图上摆有一些物体.从每一列的底端往上扔回旋镖,每镖中一个东西,回旋镖就会向右转九十度.现在我们知道从每列i底端往上镖时撞上的物体个数ai,试构造出 ...
- spring boot:基于profile的多环境配置(spring boot 2.3.4)
一,为什么要进行多环境配置? 1,没有人会在生产环境中进行开发和测试, 所以通常会有多个环境的划分: 工程师本地的开发环境 进行测试的测试环境 最终上线的生产环境 每个环境对应不同的数据库/缓存等数据 ...
- flink 处理实时数据的三重保障
flink 处理实时数据的三重保障 window+watermark 来处理乱序数据对于 TumblingEventTimeWindows window 的元数据startTime,endTime 和 ...
- 忘记MySQL密码怎么办?一招教你搞定!
在安装完 MySQL 或者是在使用 MySQL 时,最尴尬的就是忘记密码了,墨菲定律也告诉我们,如果一件事有可能出错,那么它一定会出错.那如果我们不小心忘记了 MySQL 的密码,该如何处理呢?别着急 ...
- 微信小程序分类的实现
微信小程序的分类功能思路 实现思路 1.把屏幕当成一个固定的盒子,然后把盒子分成两边,并让盒子的每一边都能够滚动. 2.通过将左侧边栏元素的id和右边内容的categoryId进行匹配,渲染展示相同i ...