幽灵资源网 Design By www.bzswh.com
如下所示:
> import pandas as pd > import numpy as np > from pandas import Series, DataFrame > df = DataFrame({'name':['a','a','b','b'],'classes':[1,2,3,4],'price':[11,22,33,44]}) > df classes name price 0 1 a 11 1 2 a 22 2 3 b 33 3 4 b 44 >
根据index和columns取值
> s = df.loc[0,'price'] > s 11
根据同行的columns的值取同行的另一个columns的值
> sex = df.loc[(df.classes==1)&(df.name=='a'),'price'] > sex 0 11 Name: price, dtype: int64 > sex = df.loc[(df.classes==1)&(df.name=='a'),'price'].values[0] > sex 11
根据条件同时取得多个值
> name,price = df.loc[df.classes==1,('name','price')].values[0] > name 'a' > price 11 >
对一列赋值
> df.loc[: , 'price']=0 > df classes name price 0 1 a 0 1 2 a 0 2 3 b 0 3 4 b 0 >
对df的一个列进行函数运算
【1】 > df['name'] = df['name'].apply(lambda x: x.upper()) > df classes name price 0 1 A 11 1 2 A 22 2 3 B 33 3 4 B 44 【2】 > df.loc[:, 'name'] = df['name'].apply(lambda x: x.upper()) > df classes name price 0 1 A 11 1 2 A 22 2 3 B 33 3 4 B 44 >
对df的几个列进行函数运算
【1】 > df[['classes','price']] = df[['classes', 'price']].applymap(lambda x: str(x)) > print(type(df.loc[0, "classes"])) <class 'str'> > print(df.loc[0, "classes"]) 1 【2】 > df.loc[:, ['classes','price']] = df[['classes', 'price']].applymap(lambda x: int(x)) > print(type(df.loc[0, "classes"])) <class 'int'> > print(df.loc[0, "classes"]) 1 >
对两个列进行去重
> df classes name price 0 1 a 11 1 1 a 22 2 3 b 33 3 4 b 44 > df.drop_duplicates(subset=['classes', 'name'], inplace=True) > df classes name price 0 1 a 11 2 3 b 33 3 4 b 44
多个条件分割字符串
> fund_memeber = '赵四、 王五' > fund_manager_list = re.split('[;, 、]', fund_memeber) > fund_manager_list ['赵四', '', '王五'] #DataFrame构造器 > df = DataFrame({'x':[1],'y':[2]}) > df x y 0 1 2 >
删除某列值为特定值得那一行
> df = DataFrame({'name':['a','b','c','d'],'classes':[1,2,3,4],'price':[11,22,33,44]}) > df classes name price 0 1 a 11 1 2 b 22 2 3 c 33 3 4 d 44 【方法一】 > df = df.loc[df['name']!='a'] > df classes name price 1 2 b 22 2 3 c 33 3 4 d 44 > 【方法二】 df.drop(df[df.name=='a'].index,axis=0) #筛选df的每列值包含某个字段‘/a' > import pandas as pd > df = pd.DataFrame({'a':['A', 'B'], 'b': ['AA', 'BB']}) > df a b 0 A AA 1 B BB > df[df['a'].str.contains(r'A')] a b 0 A AA > df = pd.DataFrame({'a':['/api/', 'B'], 'b': ['AA', 'BB']}) > df a b 0 /api/ AA 1 B BB > df[df['a'].str.contains(r'/api/')] a b 0 /api/ AA >
把列变成index和把index变成列
df request_url visit_times 9 fofeasy_产品基本信息 7 8 投顾挖掘 6 5 投顾挖掘 5 6 投顾挖掘 5 7 fofeasy_产品基本信息 5 3 fofeasy_产品基本信息 4 4 fofeasy_产品基本信息 4 2 投顾挖掘 2 0 行业数据——其他 1 1 行业数据——其他 1 x = df.set_index('request_url') x visit_times request_url fofeasy_产品基本信息 7 投顾挖掘 6 投顾挖掘 5 投顾挖掘 5 fofeasy_产品基本信息 5 fofeasy_产品基本信息 4 fofeasy_产品基本信息 4 投顾挖掘 2 行业数据——其他 1 行业数据——其他 1 x.reset_index('request_url') request_url visit_times 0 fofeasy_产品基本信息 7 1 投顾挖掘 6 2 投顾挖掘 5 3 投顾挖掘 5 4 fofeasy_产品基本信息 5 5 fofeasy_产品基本信息 4 6 fofeasy_产品基本信息 4 7 投顾挖掘 2 8 行业数据——其他 1 9 行业数据——其他 1
pandas 按照列A分组,将同一组的列B求和,生成新的Dataframe
>df.groupby(by=['request_url'])['visit_times'].sum() > request_url fofeasy_产品基本信息 20 投顾挖掘 18 行业数据——其他 2 Name: visit_times, dtype: int64
dict变成dataframe
In [15]: dict = pd.DataFrame({'x':1, 'y':2}, index=[0]) In [16]: dict Out[16]: x y 0 1 2
iloc
In [69]: df1.iloc[1:5, 2:4] Out[69]: 4 6 2 0.301624 -2.179861 4 1.462696 -1.743161 6 1.314232 0.690579 8 0.014871 3.357427
以上这篇dataframe设置两个条件取值的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
标签:
dataframe,取值
幽灵资源网 Design By www.bzswh.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
幽灵资源网 Design By www.bzswh.com
暂无评论...
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。