pandas的引用与复制

        之前一直以为pandas任何的切片和筛选都是引用,也就是说,会改变最原始的数据。但是前几天发现并不是这样的。

        下面对最常见的几种pandas 数据截取的方式做一个整理。

import pandas as pd
def df_gen():
    l1 = [1,2,3]
    l2 = [4,5,6]
    l3 = [7,6,5]
    df_t = pd.DataFrame()
    df_t['a'] = l1
    df_t['b'] = l2
    df_t['c'] = l3
    return df_t
print 'df:', df_gen()

print 'refernece:'

df = df_gen()
d1 = df.a
d1[0] = 999
print '1', df
df = df_gen()
d1 = df.ix[0]
d1[0] = 999
print '2', df
df = df_gen()
d1 = df.loc[1,:]
d1[0] = 999
print '3', df
df = df_gen()
d1 = df['a']
d1[0] = 999
print '4', df


print 'copy:'

df = df_gen()
d1 = df.iloc[1]
d1[0] = 999
print '1', df
df = df_gen()
d1 = df[df.a > 1]
d1[0] = 999
print '2', df
df = df_gen()
d1 = df.loc[df.a > 1, 'b']
d1[0] = 999
print '3', df
        上面总共7种方式,前面四种是引用的方式,后面的三种是复制。

        输出是这样一串:

df:    a  b  c
0  1  4  7
1  2  5  6
2  3  6  5
refernece:
1      a  b  c
0  999  4  7
1    2  5  6
2    3  6  5
1      a  b  c
0  999  4  7
1    2  5  6
2    3  6  5
1      a  b  c
0    1  4  7
1  999  5  6
2    3  6  5
1      a  b  c
0  999  4  7
1    2  5  6
2    3  6  5
copy:
F:/int/ProjectIntern/DatabaseTransfer/dd.py:37: SettingWithCopyWarning: 
A value is trying to be set on a copy of a slice from a DataFrame


See the caveats in the documentation: http://pandas.pydata.org/pandas-docs/stable/indexing.html#indexing-view-versus-copy
  d1[0] = 999
1    a  b  c
0  1  4  7
1  2  5  6
2  3  6  5
1 F:/int/ProjectIntern/DatabaseTransfer/dd.py:41: SettingWithCopyWarning: 
A value is trying to be set on a copy of a slice from a DataFrame.
Try using .loc[row_indexer,col_indexer] = value instead


See the caveats in the documentation: http://pandas.pydata.org/pandas-docs/stable/indexing.html#indexing-view-versus-copy
  d1[0] = 999
   a  b  c
0  1  4  7
1  2  5  6
2  3  6  5
1    a  b  c
0  1  4  7
1  2  5  6
2  3  6  5
        我们发现pandas不是refernce的时候会有警告。refernce的时候,df原始的值被改变了,说明d1只是一个引用,而后面的copy则不然。

        在使用pandas的时候要注意这一特性。

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

钱塘小甲子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值