pandas重新索引
- #重新索引会更改DataFrame的行标签和列标签。重新索引意味着符合数据以匹配特定轴上的一组给定的标签。
- #可以通过索引来实现多个操作 -
- #重新排序现有数据以匹配一组新的标签。
- #在没有标签数据的标签位置插入缺失值(NA)标记。
- #示例
- import pandas as pd
- import numpy as np
- N=20
- df = pd.DataFrame({
- 'A': pd.date_range(start='2016-01-01',periods=N,freq='D'),
- 'x': np.linspace(0,stop=N-1,num=N),
- 'y': np.random.rand(N),
- 'C': np.random.choice(['Low','Medium','High'],N).tolist(),
- 'D': np.random.normal(100, 10, size=(N)).tolist()
- })
- #reindex the DataFrame
- df_reindexed = df.reindex(index=[0,2,5], columns=['A', 'C', 'B'])
- print (df_reindexed)
- #Python
- #执行上面示例代码,得到以下结果 -
- A C B
- 0 2016-01-01 Low NaN
- 2 2016-01-03 High NaN
- 5 2016-01-06 Low NaN
- #Shell
- #重建索引与其他对象对齐
- #有时可能希望采取一个对象和重新索引,其轴被标记为与另一个对象相同。 考虑下面的例子来理解这一点。
- #示例
- import pandas as pd
- import numpy as np
- df1 = pd.DataFrame(np.random.randn(10,3),columns=['col1','col2','col3'])
- df2 = pd.DataFrame(np.random.randn(7,3),columns=['col1','col2','col3'])
- df1 = df1.reindex_like(df2)
- print df1
- #Python
- #执行上面示例代码,得到以下结果 -
- col1 col2 col3
- 0 -2.467652 -1.211687 -0.391761
- 1 -0.287396 0.522350 0.562512
- 2 -0.255409 -0.483250 1.866258
- 3 -1.150467 -0.646493 -0.222462
- 4 0.152768 -2.056643 1.877233
- 5 -1.155997 1.528719 -1.343719
- 6 -1.015606 -1.245936 -0.295275
- #Shell
- #注意 - 在这里,df1数据帧(DataFrame)被更改并重新编号,如df2。 列名称应该匹配,否则将为整个列标签添加NAN。
- #填充时重新加注
- #reindex()采用可选参数方法,它是一个填充方法,其值如下:
- #pad/ffill - 向前填充值
- #bfill/backfill - 向后填充值
- #nearest - 从最近的索引值填充
- #示例
- import pandas as pd
- import numpy as np
- df1 = pd.DataFrame(np.random.randn(6,3),columns=['col1','col2','col3'])
- df2 = pd.DataFrame(np.random.randn(2,3),columns=['col1','col2','col3'])
- # Padding NAN's
- print df2.reindex_like(df1)
- # Now Fill the NAN's with preceding Values
- print ("Data Frame with Forward Fill:")
- print df2.reindex_like(df1,method='ffill')
- #Python
- #执行上面示例代码时,得到以下结果 -
- col1 col2 col3
- 0 1.311620 -0.707176 0.599863
- 1 -0.423455 -0.700265 1.133371
- 2 NaN NaN NaN
- 3 NaN NaN NaN
- 4 NaN NaN NaN
- 5 NaN NaN NaN
- Data Frame with Forward Fill:
- col1 col2 col3
- 0 1.311620 -0.707176 0.599863
- 1 -0.423455 -0.700265 1.133371
- 2 -0.423455 -0.700265 1.133371
- 3 -0.423455 -0.700265 1.133371
- 4 -0.423455 -0.700265 1.133371
- 5 -0.423455 -0.700265 1.133371
- #Shell
- #注 - 最后四行被填充了。
- #重建索引时的填充限制
- #限制参数在重建索引时提供对填充的额外控制。限制指定连续匹配的最大计数。考虑下面的例子来理解这个概念 -
- #示例
- import pandas as pd
- import numpy as np
- df1 = pd.DataFrame(np.random.randn(6,3),columns=['col1','col2','col3'])
- df2 = pd.DataFrame(np.random.randn(2,3),columns=['col1','col2','col3'])
- # Padding NAN's
- print df2.reindex_like(df1)
- # Now Fill the NAN's with preceding Values
- print ("Data Frame with Forward Fill limiting to 1:")
- print df2.reindex_like(df1,method='ffill',limit=1)
- #Python
- #在执行上面示例代码时,得到以下结果 -
- col1 col2 col3
- 0 0.247784 2.128727 0.702576
- 1 -0.055713 -0.021732 -0.174577
- 2 NaN NaN NaN
- 3 NaN NaN NaN
- 4 NaN NaN NaN
- 5 NaN NaN NaN
- #Data Frame with Forward Fill limiting to 1:
- col1 col2 col3
- 0 0.247784 2.128727 0.702576
- 1 -0.055713 -0.021732 -0.174577
- 2 -0.055713 -0.021732 -0.174577
- 3 NaN NaN NaN
- 4 NaN NaN NaN
- 5 NaN NaN NaN
- #Shell
- #注意 - 只有第7行由前6行填充。 然后,其它行按原样保留。
- #重命名
- #rename()方法允许基于一些映射(字典或者系列)或任意函数来重新标记一个轴。
- #看看下面的例子来理解这一概念。
- #示例
- import pandas as pd
- import numpy as np
- df1 = pd.DataFrame(np.random.randn(6,3),columns=['col1','col2','col3'])
- print df1
- print ("After renaming the rows and columns:")
- print df1.rename(columns={'col1' : 'c1', 'col2' : 'c2'},index = {0 : 'apple', 1 : 'banana', 2 : 'durian'})
- #Python
- #执行上面示例代码,得到以下结果 -
- col1 col2 col3
- 0 0.486791 0.105759 1.540122
- 1 -0.990237 1.007885 -0.217896
- 2 -0.483855 -1.645027 -1.194113
- 3 -0.122316 0.566277 -0.366028
- 4 -0.231524 -0.721172 -0.112007
- 5 0.438810 0.000225 0.435479
- #After renaming the rows and columns:
- c1 c2 col3
- apple 0.486791 0.105759 1.540122
- banana -0.990237 1.007885 -0.217896
- durian -0.483855 -1.645027 -1.194113
- 3 -0.122316 0.566277 -0.366028
- 4 -0.231524 -0.721172 -0.112007
- 5 0.438810 0.000225 0.435479
- #Shell
- #rename()方法提供了一个inplace命名参数,默认为False并复制底层数据。 指定传递inplace = True则表示将数据重命名。
pandas重新索引的更多相关文章
- pandas重置索引的几种方法探究
pandas重置索引的几种方法探究 reset_index() reindex() set_index() 函数名字看起来非常有趣吧! 不仅如此. 需要探究. http://nbviewer.jupy ...
- (三)pandas 层次化索引
pandas层次化索引 1. 创建多层行索引 1) 隐式构造 最常见的方法是给DataFrame构造函数的index参数传递两个或更多的数组 Series也可以创建多层索引 import numpy ...
- pandas 数据索引与选取
我们对 DataFrame 进行选择,大抵从这三个层次考虑:行列.区域.单元格.其对应使用的方法如下:一. 行,列 --> df[]二. 区域 --> df.loc[], df.ilo ...
- Pandas之索引
Pandas的标签处理需要分成多种情况来处理,Series和DataFrame根据标签索引数据的操作方法是不同的,单列索引和双列索引的操作方法也是不同的. 单列索引 In [2]: import pa ...
- pandas DataFrame 索引(iloc 与 loc 的区别)
Pandas--ix vs loc vs iloc区别 0. DataFrame DataFrame 的构造主要依赖如下三个参数: data:表格数据: index:行索引: columns:列名: ...
- Pandas重建索引
重新索引会更改DataFrame的行标签和列标签.重新索引意味着符合数据以匹配特定轴上的一组给定的标签. 可以通过索引来实现多个操作 - 重新排序现有数据以匹配一组新的标签. 在没有标签数据的标签位置 ...
- pandas层级索引1
层级索引(hierarchical indexing) 下面创建一个Series, 在输入索引Index时,输入了由两个子list组成的list,第一个子list是外层索引,第二个list是内层索引. ...
- pandas层级索引
层级索引(hierarchical indexing) 下面创建一个Series, 在输入索引Index时,输入了由两个子list组成的list,第一个子list是外层索引,第二个list是内层索引. ...
- python库学习笔记——Pandas数据索引:ix、loc、iloc区别
Different Choices for Indexing 1. loc--通过行标签索引行数据 1.1 loc[1]表示索引的是第1行(index 是整数) import pandas as pd ...
随机推荐
- Springmvc导出Excel(maven)
一.导入依赖 <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</ar ...
- SSM框架之整合(Maven实例)
有不少朋友在maven中因为pom文件依赖的事导致报错 今天我这个快速搭建ssm框架,确保在jdk7或者jdk8的环境,tomcat没什么要求.但如果要用jdk8的话,最好用run as中的serve ...
- ubuntu 系统判断优盘的指定文件存在
有很多的时候 会出现没有用的优盘路径 如果代码中写的是绝对路径 就有可能读不到优盘的内容 ,以下代码就是可以解决这样的问题 我已经封装成一个类 upanpath.h #ifndef UPANPATH_ ...
- ubuntu下修改网卡名称
Ubuntu下把网卡eth0修改为eth1的步骤: 1.打开配置文件 /etc/udev/rules.d/70-persistent-net.rules,文件内容如下: # This file was ...
- MySQL(十三)事务处理和字符集
一.事务处理 事务处理(transaction processing):是一种机制,用来维护数据库的完整性,管理必须成批执行的MySQL操作,以保证数据库不包含不完整的操作结果. 这样可以保证一组操作 ...
- at android.view.Surface.unlockCanvasAndPost(Native Method)
at android.view.Surface.unlockCanvasAndPost(Native Method) 在绘制动画特效的时候点击back键会报以上异常. 主要原因:当点击back按钮时A ...
- linux中断源码分析 - 软中断(四)
本文为原创,转载请注明:http://www.cnblogs.com/tolimit/ 在上一篇文章中,我们看到中断实际分为了两个部分,俗称就是一部分是硬中断,一部分是软中断.软中断是专门用于处理中断 ...
- Luogu3877 TJOI2010 打扫房间 二分图、网络流
传送门 真是菜死了模板题都不会-- 首先\(30 \times 30\)并不能插头DP,但是范围仍然很小所以考虑网络流. 注意每个点都要包含在一个回路中,那么每一个点的度数都必须为\(2\),也就是说 ...
- (转)Putty server refused our key的三种原因和解决方法
原文 上一篇博文介绍了使用Putty免密码登录,我后面试了另一台虚拟机,结果putty显示错误server refused our key(在linux下则表现为仍需要输入密码),搜索了下,很多人都遇 ...
- Luogu P3953 逛公园
不管怎么说,这都是一道十分神仙的NOIp题 你可以说它狗,但不可以否认它就是NOIp的难度 首先这道题很显然是道图论题还是一道图论三合一(最短路+拓扑+图上DP) 先考虑最短路,我们分别以\(1\)和 ...