开始之前,pandas中DataFrame删除对象可能存在几种情况
1、删除具体列
2、删除具体行
3、删除包含某些数值的行或者列
4、删除包含某些字符、文字的行或者列
本文就针对这四种情况探讨一下如何操作。
数据准备
模拟了一份股票交割的记录。
In [1]: import pandas as pd In [2]: data = { ...: '证券名称' : ['格力电器','视觉中国','成都银行','中国联通','格力电器','视觉中国','成都银行','中国联通'], ...: '摘要': ['证券买入','证券买入','证券买入','证券买入','证券卖出','证券卖出','证券卖出','证券卖出'], ...: '成交数量' : [500,1000,1500,2000,500,500,1000,1500], ...: '成交金额' : [-5000,-10000,-15000,-20000,5500,5500,11000,15000] ...: } ...: In [3]: df = pd.DataFrame(data, index = ['2018-2-1','2018-2-1','2018-2-1','2018-2-1','2018-2-2','2018-2-2','2018-2-2','2018-2-3']) In [4]: df Out[4]: 成交数量 成交金额 摘要 证券名称 2018-2-1 500 -5000 证券买入 格力电器 2018-2-1 1000 -10000 证券买入 视觉中国 2018-2-1 1500 -15000 证券买入 成都银行 2018-2-1 2000 -20000 证券买入 中国联通 2018-2-2 500 5500 证券卖出 格力电器 2018-2-2 500 5500 证券卖出 视觉中国 2018-2-2 1000 11000 证券卖出 成都银行 2018-2-3 1500 15000 证券卖出 中国联通
删除具体列
In [5]: df.drop('成交数量',axis=1) Out[5]: 成交金额 摘要 证券名称 2018-2-1 -5000 证券买入 格力电器 2018-2-1 -10000 证券买入 视觉中国 2018-2-1 -15000 证券买入 成都银行 2018-2-1 -20000 证券买入 中国联通 2018-2-2 5500 证券卖出 格力电器 2018-2-2 5500 证券卖出 视觉中国 2018-2-2 11000 证券卖出 成都银行 2018-2-3 15000 证券卖出 中国联通
删除具体行
In [6]: df.drop('2018-2-3') Out[6]: 成交数量 成交金额 摘要 证券名称 2018-2-1 500 -5000 证券买入 格力电器 2018-2-1 1000 -10000 证券买入 视觉中国 2018-2-1 1500 -15000 证券买入 成都银行 2018-2-1 2000 -20000 证券买入 中国联通 2018-2-2 500 5500 证券卖出 格力电器 2018-2-2 500 5500 证券卖出 视觉中国 2018-2-2 1000 11000 证券卖出 成都银行
也可以根据行号删除记录,比如删除第三行
In [22]: df.drop(df.index[7]) Out[22]: 成交数量 成交金额 摘要 证券名称 2018-2-1 500 -5000 证券买入 格力电器 2018-2-1 1000 -10000 证券买入 视觉中国 2018-2-1 1500 -15000 证券买入 成都银行 2018-2-1 2000 -20000 证券买入 中国联通 2018-2-2 500 5500 证券卖出 格力电器 2018-2-2 500 5500 证券卖出 视觉中国 2018-2-2 1000 11000 证券卖出 成都银行
注意,这个办法其实不是按照行号删除,而是按照索引删除。如果index为3,则会将前4条记录都删除。这个方法支持一个范围,以及用负数表示从末尾删除。
删除特定数值的行(删除成交金额小于10000)
In [7]: df[ df['成交金额'] > 10000] Out[7]: 成交数量 成交金额 摘要 证券名称 2018-2-2 1000 11000 证券卖出 成都银行 2018-2-3 1500 15000 证券卖出 中国联通
本例其实是筛选,如果需要保留,可以将筛选后的对象赋值给自己即可。
删除某列包含特殊字符的行
In [11]: df[ ~ df['证券名称'].str.contains('联通') ] Out[11]: 成交数量 成交金额 摘要 证券名称 2018-2-1 500 -5000 证券买入 格力电器 2018-2-1 1000 -10000 证券买入 视觉中国 2018-2-1 1500 -15000 证券买入 成都银行 2018-2-2 500 5500 证券卖出 格力电器 2018-2-2 500 5500 证券卖出 视觉中国 2018-2-2 1000 11000 证券卖出 成都银行
如果想取包含某些字符的记录,可以去掉~
In [12]: df[ df['证券名称'].str.contains('联通') ] Out[12]: 成交数量 成交金额 摘要 证券名称 2018-2-1 2000 -20000 证券买入 中国联通 2018-2-3 1500 15000 证券卖出 中国联通
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 【雨果唱片】中国管弦乐《鹿回头》WAV
- APM亚流新世代《一起冒险》[FLAC/分轨][106.77MB]
- 崔健《飞狗》律冻文化[WAV+CUE][1.1G]
- 罗志祥《舞状元 (Explicit)》[320K/MP3][66.77MB]
- 尤雅.1997-幽雅精粹2CD【南方】【WAV+CUE】
- 张惠妹.2007-STAR(引进版)【EMI百代】【WAV+CUE】
- 群星.2008-LOVE情歌集VOL.8【正东】【WAV+CUE】
- 罗志祥《舞状元 (Explicit)》[FLAC/分轨][360.76MB]
- Tank《我不伟大,至少我能改变我。》[320K/MP3][160.41MB]
- Tank《我不伟大,至少我能改变我。》[FLAC/分轨][236.89MB]
- CD圣经推荐-夏韶声《谙2》SACD-ISO
- 钟镇涛-《百分百钟镇涛》首批限量版SACD-ISO
- 群星《继续微笑致敬许冠杰》[低速原抓WAV+CUE]
- 潘秀琼.2003-国语难忘金曲珍藏集【皇星全音】【WAV+CUE】
- 林东松.1997-2039玫瑰事件【宝丽金】【WAV+CUE】