gpt4 book ai didi

python - Pandas 数据框查询

转载 作者:行者123 更新时间:2023-12-01 01:23:53 24 4
gpt4 key购买 nike

我喜欢根据列名及其最小值和最大值检索数据。我不知道如何得到这个结果。我能够根据列名称获取数据,但不明白如何应用限制。

列表和元组中给出的列名称以及相应的最小值和最大值。

import pandas as pd
import numpy as np

def c_cutoff(data_frame, column_cutoff):

selected_data = data_frame.loc[:, [X[0] for X in column_cutoff]]

return selected_data


np.random.seed(5)
df = pd.DataFrame(np.random.randint(100, size=(100, 6)),
columns=list('ABCDEF'),
index=['R{}'.format(i) for i in range(100)])

column_cutoffdata = [('B',27,78),('E',44,73)]

newdata_cutoff = c_cutoff(df,column_cutoffdata)
print(df.head())


print(newdata_cutoff)

结果

    B   E
R0 78 73
R1 27 7
R2 53 44
R3 65 84
R4 9 1
..
.

预期输出我希望所有小于 27 和大于 78 的值都应该被丢弃,E 也是如此

最佳答案

您可以相当明确地执行以下操作:

lim = [('B',27,78),('E',44,73)]

for lim in limiters:
df = df[(df[lim[0]]>=lim[1]) & (df[lim[0]]<=lim[2])]

产量:

      A   B   C   D   E   F
R0 99 78 61 16 73 8
R2 15 53 80 27 44 77
R8 30 62 11 67 65 55
R11 90 31 9 38 47 16
R15 16 64 8 90 44 37
R16 94 75 5 22 52 69
R46 11 30 26 8 51 61
R48 39 59 22 80 58 44
R66 55 38 5 49 58 15
R70 36 78 5 13 73 69
R72 70 58 52 99 67 11
R75 20 59 57 33 53 96
R77 32 31 89 49 69 41
R79 43 28 17 16 73 54
R80 45 34 90 67 69 70
R87 9 50 16 61 65 30
R90 43 56 76 7 47 62

关于python - Pandas 数据框查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53527790/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com