首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >熊猫数据中的字符串和整数(基于条件)

熊猫数据中的字符串和整数(基于条件)
EN

Stack Overflow用户
提问于 2017-07-05 08:26:20
回答 1查看 5.6K关注 0票数 2

在我的dataframe中有2列:

  1. 国家指数(例如SK)
  2. Id_number(通常为8位数,例如:98341852)

我想把它们连接起来,这很简单:

代码语言:javascript
运行
复制
sk_df['id'] = sk_df['country index'].str.cat(sk_df['id_number'].values.astype(str))

但是列id_number中的一些行的数字小于8。在本例中,我希望在Country索引和id_number之间添加零作为分隔符(例如,如果id_number的长度为6,则希望在变量之间添加8-6 =2个零:SK00813841 )。如果id_number长度为7,请添加1 0等)

我试过这个:

代码语言:javascript
运行
复制
def indexing(row):
    if row['id_number'].astype(str).str.len() == 8:
        return row['country index'].str.cat(row['id_number'].values.astype(str))
    else:
        sep_mult = 8 - row['id_number'].astype(str).str.len()
        return row['country index'].str.cat(row['id_number'].values.astype(str),sep = '0'*sep_mult)



sk_df['id'] = sk_df.apply(lambda row: indexing(row),axis = 1)

但不起作用。我该怎么做呢?

EN

回答 1

Stack Overflow用户

发布于 2017-07-05 08:48:41

使用.zfill()

代码语言:javascript
运行
复制
sk_df['id'] = sk_df['country index'] + sk_df['id_number'].astype(str).str.zfill(8)
票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44920796

复制
相关文章

相似问题

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