当前位置:   article > 正文

Dataframe添加行、列的方法_dataframe添加一行

dataframe添加一行

在Pandas的DataFrame中添加一行或者一列,添加行有df.loc[]以及df.append()这两种方法,添加列有df[]df.insert()两种方法, 下面对这几种方法的使用进行简单介绍。

一、添加行

  1. 添加一行,采用loc[]方法

  1. # 构造一个空的dataframe
  2. import pandas as pd
  3. df = pd.DataFrame(columns=['name','number'])
  4. # 采用.loc的方法进行
  5. df.loc[0]=['cat', 3] # 其中loc[]中需要加入的是插入地方dataframe的索引,默认是整数型
  6. # 也可采用诸如df.loc['a'] = ['123',30]的形式

采用loc[]方法多适用于对空的dataframe循环遍历添加行,这样索引可以从0开始直到数据结果,不会存在索引冲突的问题。

  1. 添加一行或合并两个dataframe,采用append()方法

  1. # 1. 采用append方法合并两个dataframe
  2. # 构造两个dataframe
  3. df = pd.DataFrame([[1, 2], [3, 4]], columns=list('AB'))
  4. df2 = pd.DataFrame([[5, 6], [7, 8]], columns=list('AB'))
  5. # 合并 ignore_index设置为 True可以重新排列索引
  6. df.append(df2, ignore_index=True)
  7. A B
  8. 0 1 2
  9. 1 3 4
  10. 2 5 6
  11. 3 7 8
  12. # 2. 采用append方法添加多行
  13. df = pd.DataFrame(columns=['A'])
  14. for i in range(5):
  15. df = df.append({'A': i}, ignore_index=True)
  16. df
  17. A
  18. 0 0
  19. 1 1
  20. 2 2
  21. 3 3
  22. 4 4
  23. # 同样如果是遍历添加多行,有一种更高效的方法
  24. pd.concat([pd.DataFrame([i], columns=['A']) for i in range(5)],
  25. ignore_index=True)
  26. A
  27. 0 0
  28. 1 1
  29. 2 2
  30. 3 3
  31. 4 4

二、添加列

  1. 新增一列,采用df[]方法直接在列上操作

  1. # 新建一个dataframe
  2. df = pd.DataFrame(columns=['name','number'], data=[['cat',3]])
  3. df
  4. name number
  5. 0 cat 3
  6. # 添加一列,计算有多少条腿
  7. df['leg'] = df['number'] * 4
  8. # 添加一列,直接赋值有几个头
  9. df['head'] = 1
  10. df
  11. name number leg head
  12. 0 cat 3 12 1
  1. 添加一列,采用insert()方法

  1. # 使用方法是DataFrame.insert(loc, column, value, allow_duplicates=False)
  2. # 即df.insert(添加列位置索引序号,添加列名,数值,是否允许列名重复)
  3. df.insert(1, 'tail', 1, allow_duplicates=False)
  4. df
  5. name tail number leg head
  6. 0 cat 1 3 12 1

不过在使用insert的过程中发现454: DeprecationWarning: `input_splitter` is deprecated since IPython 7.0, prefer `input_transformer_manager`. status, indent_spaces = self.shell.input_splitter.check_complete(code)这个提示,猜测该方法可能已经过时了,不提倡使用了。

主要参考资料:

  1. pandas.DataFrame.append
  2. pandas.DataFrame.insert



作者:王叽叽的小心情
链接:https://www.jianshu.com/p/936ad27d9865
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/花生_TL007/article/detail/198071?site
推荐阅读
相关标签
  

闽ICP备14008679号