一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術(shù)及教程分享平臺!
分類導(dǎo)航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務(wù)器之家 - 腳本之家 - Python - dataframe設(shè)置兩個條件取值的實例

dataframe設(shè)置兩個條件取值的實例

2021-01-30 00:43GeekLeee Python

下面小編就為大家分享一篇dataframe設(shè)置兩個條件取值的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

如下所示:

?
1
2
3
4
5
6
7
8
9
10
11
>>> 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
>>>

根據(jù)index和columns取值

?
1
2
3
>>> s = df.loc[0,'price']
>>> s
11

根據(jù)同行的columns的值取同行的另一個columns的值

?
1
2
3
4
5
6
7
>>> 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

根據(jù)條件同時取得多個值

?
1
2
3
4
5
6
>>> name,price = df.loc[df.classes==1,('name','price')].values[0]
>>> name
'a'
>>> price
11
>>>

對一列賦值

?
1
2
3
4
5
6
7
8
>>> 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的一個列進行函數(shù)運算

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
【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的幾個列進行函數(shù)運算

?
1
2
3
4
5
6
7
8
9
10
11
12
13
【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
>>>

對兩個列進行去重

?
1
2
3
4
5
6
7
8
9
10
11
12
>>> 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

多個條件分割字符串

?
1
2
3
4
5
6
7
8
9
10
>>> fund_memeber = '趙四、 王五'
>>> fund_manager_list = re.split('[;, 、]', fund_memeber)
>>> fund_manager_list
['趙四', '', '王五']
#DataFrame構(gòu)造器
>>> df = DataFrame({'x':[1],'y':[2]})
>>> df
 x y
0 1 2
>>>

刪除某列值為特定值得那一行

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
>>> 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變成列

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
df
  request_url visit_times
9 fofeasy_產(chǎn)品基本信息   7
8   投顧挖掘   6
5   投顧挖掘   5
6   投顧挖掘   5
7 fofeasy_產(chǎn)品基本信息   5
3 fofeasy_產(chǎn)品基本信息   4
4 fofeasy_產(chǎn)品基本信息   4
2   投顧挖掘   2
0  行業(yè)數(shù)據(jù)——其他   1
1  行業(yè)數(shù)據(jù)——其他   1
x = df.set_index('request_url')
x
    visit_times
request_url   
fofeasy_產(chǎn)品基本信息   7
投顧挖掘      6
投顧挖掘      5
投顧挖掘      5
fofeasy_產(chǎn)品基本信息   5
fofeasy_產(chǎn)品基本信息   4
fofeasy_產(chǎn)品基本信息   4
投顧挖掘      2
行業(yè)數(shù)據(jù)——其他     1
行業(yè)數(shù)據(jù)——其他     1
x.reset_index('request_url')
  request_url visit_times
0 fofeasy_產(chǎn)品基本信息   7
1   投顧挖掘   6
2   投顧挖掘   5
3   投顧挖掘   5
4 fofeasy_產(chǎn)品基本信息   5
5 fofeasy_產(chǎn)品基本信息   4
6 fofeasy_產(chǎn)品基本信息   4
7   投顧挖掘   2
8  行業(yè)數(shù)據(jù)——其他   1
9  行業(yè)數(shù)據(jù)——其他   1

pandas 按照列A分組,將同一組的列B求和,生成新的Dataframe

?
1
2
3
4
5
6
7
>>>df.groupby(by=['request_url'])['visit_times'].sum()
>>>
request_url
fofeasy_產(chǎn)品基本信息 20
投顧挖掘    18
行業(yè)數(shù)據(jù)——其他   2
Name: visit_times, dtype: int64

dict變成dataframe

?
1
2
3
4
5
In [15]: dict = pd.DataFrame({'x':1, 'y':2}, index=[0])
In [16]: dict
Out[16]:
 x y
0 1 2

iloc

?
1
2
3
4
5
6
7
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設(shè)置兩個條件取值的實例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持服務(wù)器之家。

原文鏈接:https://blog.csdn.net/GeekLeee/article/details/75268762

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 欧美日韩国产在线人成 | 色视频亚洲 | 亚洲天堂网站 | 日韩欧美国内 | www.四虎在线观看 | 性欧美video| 东北美女野外bbwbbw免费 | 双性肉文高h | 69人成网站色www | 免费人成黄页在线观看69 | av在线亚洲男人的天堂 | 高清男的插曲女的 欢迎你老狼 | 国产黑丝一区 | 欧美成a人片免费看久久 | 色欲麻豆国产福利精品 | 调教全程肉动画片在线观看 | 成年人免费在线看 | 久久亚洲高清观看 | 暖暖的免费观看高清视频韩国 | 欧美午夜视频一区二区三区 | 狠狠插入 | 激情视频网址 | 亚洲日本视频在线观看 | 欧美精品一区二区在线观看播放 | 欧美日韩看看2015永久免费 | 虎四免费入口 | 国产suv精品一区二区四区三区 | 极品美女aⅴ高清在线观看 极品ts赵恩静和直男激战啪啪 | 牛牛在线观看 | 国产免费看视频 | 无人知晓小说姜璟免费阅读 | 99在线资源 | 国内精品久久久久久久久 | 美女被草出水 | 国产综合久久久久久 | 国产99精品视频 | 被黑人同学彻底征服全文小说阅读 | 亚洲第一二三四区 | 亚洲精品无码久久不卡 | 亚洲无毛片 | 欧美日韩国产精品自在自线 |