首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如果该值介于x和y之间,则将其更改为z (pd df)。

如果该值介于x和y之间,则将其更改为z (pd df)。
EN

Stack Overflow用户
提问于 2022-08-03 16:07:49
回答 3查看 57关注 0票数 0

考虑:

代码语言:javascript
复制
data.loc[data.cig_years (10 < a < 20), 'cig_years'] = 1

这是我试过的代码,但不起作用。我想用伪码:

代码语言:javascript
复制
In the df 'data'
    In the column 'cig_years'
        If the value is a number between 10 and 20, change it to 1

有什么毕达通的方法吗?最好没有for循环。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2022-08-03 16:28:12

我抓住你了。您可以使用方括号[]过滤熊猫的数据:

代码语言:javascript
复制
data['cig_years'] [ (data['cig_years']>10) | (data['cig_years']<20) ] = 1

这基本上是说:

数据中的列'cig_years‘,其中列'cig_years’大于10,或小于‘cig_years’,则设置为1

这在熊猫数据访问中非常有用,因为您可以对特定列进行筛选,或者根据其他列上的条件进行筛选,然后设置已过滤的值。

票数 0
EN

Stack Overflow用户

发布于 2022-08-03 16:30:04

您需要使用您的dataframe名称"data“,并使用.loc更改它,如下所示:

代码语言:javascript
复制
data.loc[10 < data['cig_years'] < 20, 'cig_years'] = 1
票数 1
EN

Stack Overflow用户

发布于 2022-08-03 17:32:14

您还可以使用np.where语句,如果不是在10到20之间,则该语句假设您将单独使用cig年。

代码语言:javascript
复制
data['cig_years'] = np.where(10 < data['cig_years'] < 20, 1, data['cig_years'])
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73224465

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档