网站首页 > 技术文章 正文
concat
import pandas as pd
s1 = pd.Series([0,1,2],index=['A','B','C'])
s2 = pd.Series([3,4],index=['D','E'])
s3 = pd.concat([s1,s2]) # 默认行连接
s4 = pd.concat([s1,s2],axis=1)
print(s1)
print('*'*10)
print(s2)
print('-'*10)
print(s3)
print('='*10)
print(s4)
相同字段的表(列名一样)首尾相接
import pandas as pd
# 相同字段的表(列名一样)首尾相接
df1 = pd.DataFrame([[1,2],[3,4]],columns=['a','b'])
df2 = pd.DataFrame({'a':[5,6],'b':[7,8]},index=[2,3])
s1 = pd.Series([9,10],index=[4,5],name='a')
s2 = pd.Series([11,12],index=[4,5],name='b')
df3 = pd.DataFrame({s1.name:s1,s2.name:s2})
df = [df1,df2,df3]
c1 = pd.concat(df)
print(df1)
print("* "*10)
print(df2)
print('- '*10)
print(df3)
print('~ '*10)
print(c1)
print('+ '*10)
# 相接的时候识别数据源自于哪张表,可以增加keys参数
c2 = pd.concat([df1,df2,df3],keys=['x','y','z'])
print(c2)
# 也可通过字典来增加分组
d1 = {'X':df1,'Y':df2,'Z':df3}
c3 = pd.concat(d1)
print("* "*10)
print(c3)
横向表拼接(行对齐),axis = 1
import pandas as pd
# 横向表拼接(行对齐)
df1 = pd.DataFrame([[1,2],[3,4],[5,6]],columns=['a','b'])
df2 = pd.DataFrame({'A':[11,12,13],'B':[14,15,16]},index=[1,2,3])
# 当axis = 1的时候,concat就是行对齐,然后将不同列名称的两张表合并
c1 = pd.concat([df1,df2],axis=1)
print(df1)
print("* "*6)
print(df2)
print('- '*6)
print(c1)
# join参数,'inner':两表的交集;'outer':两表的并集
c2 = pd.concat([df1,df2],axis=1,join='inner')
c3 = pd.concat([df1,df2],axis=1,join='outer')
print('= '*6)
print(c2)
print('+ '*6)
print(c3)
无视index的concat
如果两个表的index没有实际含义,使用ignore_index参数,置True,合并的两个表就是根据列字段对齐,然后合并,最后重新整理一个新的index.
import pandas as pd
# ignore_index参数
df1 = pd.DataFrame({'A':[1,2,3],'B':[4,5,6],'C':[7,8,9]})
df2 = pd.DataFrame({'A':[11,12,13],'C':[17,18,19],'D':[20,21,22]},index=[1,2,3])
c1 = pd.concat([df1,df2],ignore_index=True)
print(df1)
print("* "*6)
print(df2)
print('- '*6)
print(c1)
参考资料:
B站:孙兴华《中文讲Python从入门到办公自动化》
猜你喜欢
- 2025-05-15 Python数据持久化:JSON
- 2025-05-15 Python自动化-Excel:openpyxl练习,求和、条件判断
- 2025-05-15 新手必看!Python 编程十大常见错误及避坑指南
- 2025-05-15 盘点3种Python网络爬虫过程中的中文乱码的处理方法
- 2025-05-15 Python自动化-Excel:pandas之填充
- 2025-05-15 [oeasy]python0129_unicode中文字符序号十三道大辙_字符编码解码
- 2025-05-15 Python自动化-Excel:pandas之merge
- 2025-05-15 python 编码知识中文乱码问题解决
- 2025-05-15 python入门教程完整版(懂中文就能学会)
- 2025-05-15 Python入门教程完整版(懂中文就能学会)
- 05-25Python 3.14 t-string 要来了,它与 f-string 有何不同?
- 05-25Python基础元素语法总结
- 05-25Python中的变量是什么东西?
- 05-25新手常见的python报错及解决方案
- 05-2511-Python变量
- 05-2510个每个人都是需要知道Python问题
- 05-25Python编程:轻松掌握函数定义、类型及其参数传递方式
- 05-25Python基础语法
- 257℃Python短文,Python中的嵌套条件语句(六)
- 257℃python笔记:for循环嵌套。end=""的作用,图形打印
- 256℃PythonNet:实现Python与.Net代码相互调用!
- 251℃Python操作Sqlserver数据库(多库同时异步执行:增删改查)
- 251℃Python实现字符串小写转大写并写入文件
- 106℃原来2025是完美的平方年,一起探索六种平方的算吧
- 91℃Python 和 JavaScript 终于联姻了!PythonMonkey 要火?
- 81℃Ollama v0.4.5-v0.4.7 更新集合:Ollama Python 库改进、新模型支持
- 最近发表
- 标签列表
-
- python中类 (31)
- python 迭代 (34)
- python 小写 (35)
- python怎么输出 (33)
- python 日志 (35)
- python语音 (31)
- python 工程师 (34)
- python3 安装 (31)
- python音乐 (31)
- 安卓 python (32)
- python 小游戏 (32)
- python 安卓 (31)
- python聚类 (34)
- python向量 (31)
- python大全 (31)
- python次方 (33)
- python桌面 (32)
- python总结 (34)
- python浏览器 (32)
- python 请求 (32)
- python 前端 (32)
- python验证码 (33)
- python 题目 (32)
- python 文件写 (33)
- python中的用法 (32)