关于“iloc cannot enlarge its target object”(iloc与loc的坑)

这个是问题代码,报“iloc cannot enlarge its target object”,也就是说iloc越界了。

# 去除非中文,与长度为一的字符
for index, row in pos.iterrows():
    temp = []
    for i in row['分词后'].split(' '):
        if '\u4e00' <= i <= '\u9fff' and len(i) > 1:
            temp.append(i)
    pos.iloc[index, 4] = " ".join(temp)

其实原因很简单,我先区分一下iloc和loc,写这俩的文章我感觉没有重点强调下面这点:

import pandas as pd

data = [[1, 10, 'A'],
        [2, 20, 'B'],
        [3, 30, 'C']]

df = pd.DataFrame(data, columns=['month', 'price', 'level'])

print(df)
#   month  price level
#0      1     10     A
#1      2     20     B
#2      3     30     C

print(df.iloc[1])
#month     2
#price    20
#level     B

print(df.loc[1])
#month     2
#price    20
#level     B

df = df.drop(1)  # 删除索引为1的行 

print(df)
#   month  price level
#0      1     10     A
#2      3     30     C

print(df.iloc[1])
#month     3
#price    30
#level     C

print(df.loc[1])
# 报错

print(df.loc[2])
#month     3
#price    30
#level     C

通过上面这个小实验,可以发现iloc[index],这个index代表着是真正的第index行;loc[index],这个index是代表着索引的标号为index的行。
所以我上面的代码改成下面这样就可以正确运行了,需要注意的是loc列那里不能写数字,要写列名。这也再次说明:iloc[row,line],行和列都是真正的位置;loc[row,line],这里的行和列可以理解为是个str,loc是找和row和line相同字符所对应的地方。

pos.loc[index, '分词后'] = " ".join(temp)
  • 8
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值