python中pandas库下使用merge、concat对数据合并和重塑

数据规整化:合并、清理、过滤

pandas和python标准库提供了一整套高级、灵活的、高效的核心函数和算法将数据规整化为你想要的形式!

本篇博客主要介绍:

合并数据集:.merge()、.concat()等方法,类似于SQL或其他关系型数据库的连接操作。

合并数据集

1) merge 函数参数

参数说明
left参与合并的左侧DataFrame
right参与合并的右侧DataFrame
how连接方式:‘inner’(默认);还有,‘outer’、‘left’、‘right’
on用于连接的列名,必须同时存在于左右两个DataFrame对象中,如果位指定,则以left和right列名的交集作为连接键
left_on左侧DataFarme中用作连接键的列
right_on右侧DataFarme中用作连接键的列
left_index将左侧的行索引用作其连接键
right_index将右侧的行索引用作其连接键
sort根据连接键对合并后的数据进行排序,默认为True。有时在处理大数据集时,禁用该选项可获得更好的性能
suffixes字符串值元组,用于追加到重叠列名的末尾,默认为(‘_x’,‘_y’).例如,左右两个DataFrame对象都有‘data’,则结果中就会出现‘data_x’,‘data_y’
copy设置为False,可以在某些特殊情况下避免将数据复制到结果数据结构中。默认总是赋值

1、多对一的合并(一个表的连接键列有重复值,另一个表中的连接键没有重复值)


   
   
  1. import pandas as pd
  2. import numpy as np
  3. df1 = pd.DataFrame({ 'key':[ 'b', 'b', 'a', 'c', 'a', 'a', 'b'], 'data1': range( 7)})
  4. df1
 data1key
00b
11b
22a
33c
44a
55a
66b

   
   
  1. df2 = pd.DataFrame({ 'key':[ 'a', 'b', 'd'], 'data2':range( 3)})
  2. df2
 data2key
00a
11b
22d
pd.merge(df1,df2)#默认情况
   
   
 data1keydata2
00b1
11b1
26b1
32a0
44a0
55a0
df1.merge(df2)
   
   
 data1keydata2
00b1
11b1
26b1
32a0
44a0
55a0
df1.merge(df2,on = 'key',how = 'inner')#内连接,取交集
   
   
 data1keydata2
00b1
11b1
26b1
32a0
44a0
55a0
df1.merge(df2,on = 'key',how = 'outer')#外链接,取并集,并用nan填充
   
   
 data1keydata2
00.0b1.0
11.0b1.0
26.0b1.0
32.0a0.0
44.0a0.0
55.0a0.0
63.0cNaN
7NaNd2.0
df1.merge(df2,on = 'key',how = 'left')#左连接,左侧DataFrame取全部,右侧DataFrame取部分
   
   
 data1keydata2
00b1.0
11b1.0
22a0.0
33cNaN
44a0.0
55a0.0
66b1.0
df1.merge(df2,on = 'key',how = 'right')#右连接,右侧DataFrame取全部,左侧DataFrame取部分
   
   
 data1keydata2
00.0b1
11.0b1
26.0b1
32.0a0
44.0a0
55.0a0
6NaNd2

如果左右侧DataFrame的连接键列名不一致,但是取值有重叠,可使用left_on、right_on来指定左右连接键


   
   
  1. df3 = pd.DataFrame({ 'lkey':[ 'b', 'b', 'a', 'c', 'a', 'a', 'b'], 'data1': range( 7)})
  2. df3
 data1lkey
00b
11b
22a
33c
44a
55a
66b

   
   
  1. df4 = pd.DataFrame({ 'rkey':[ 'a', 'b', 'd'], 'data2':range( 3)})
  2. df4
 data2rkey
00a
11b
22d
df3.merge(df4,left_on = 'lkey',right_on = 'rkey',how = 'inner')
   
   
 data1lkeydata2rkey
00b1b
11b1b
26b1b
32a0a
44a0a
55a0a

2、多对多的合并(一个表的连接键列有重复值,另一个表中的连接键有重复值)


   
   
  1. df1 = pd.DataFrame({ 'key':[ 'b', 'b', 'a', 'c', 'a', 'a', 'b'], 'data1': range( 7)})
  2. df1
 data1key
00b
11b
22a
33c
44a
55a
66b

   
   
  1. df5 = pd.DataFrame({ 'key':[ 'a', 'b', 'a', 'b', 'b'], 'data2': range( 5)})
  2. df5
 data2key
00a
11b
22a
33b
44b
df1.merge(df5)
   
   
 data1keydata2
00b1
10b3
20b4
31b1
41b3
51b4
66b1
76b3
86b4
92a0
102a2
114a0
124a2
135a0
145a2

合并小结

1)默认情况下,会将两个表中相同列名作为连接键

2)多对多,会采用笛卡尔积形式链接(左表连接键有三个值‘1,3,5’,右表有两个值‘2,3’,则会形成,(1,2)(1,3)(3,1),(3,2)。。。6种组合)

3)存在多个连接键的处理


   
   
  1. left = pd.DataFrame({ 'key1':[ 'foo', 'foo', 'bar'], 'key2':[ 'one', 'one', 'two'], 'lval':[ 1, 2, 3]})
  2. right = pd.DataFrame({ 'key1':[ 'foo', 'foo', 'bar', 'bar'], 'key2':[ 'one', 'one', 'one', 'two'], 'rval':[ 4, 5, 6, 7]})
left
   
   
 key1key2lval
0fooone1
1fooone2
2bartwo3
right
   
   
 key1key2rval
0fooone4
1fooone5
2barone6
3bartwo7
pd.merge(left,right,on = ['key1','key2'],how = 'outer')
   
   
 key1key2lvalrval
0fooone1.04
1fooone1.05
2fooone2.04
3fooone2.05
4bartwo3.07
5baroneNaN6

1)连接键是多对多关系,应执行笛卡尔积形式

2)多列应看连接键值对是否一致

4)对连接表中非连接列的重复列名的处理

pd.merge(left,right,on = 'key1')
   
   
 key1key2_xlvalkey2_yrval
0fooone1one4
1fooone1one5
2fooone2one4
3fooone2one5
4bartwo3one6
5bartwo3two7
pd.merge(left,right,on = 'key1',suffixes = ('_left','_right'))
   
   
 key1key2_leftlvalkey2_rightrval
0fooone1one4
1fooone1one5
2fooone2one4
3fooone2one5
4bartwo3one6
5bartwo3two7

2)索引上的合并

当连接键位于索引中时,成为索引上的合并,可以通过merge函数,传入left_index、right_index来说明应该被索引的情况。

  1. 一表中连接键是索引列、另一表连接键是非索引列

   
   
  1. left1 = pd.DataFrame({ 'key':[ 'a', 'b', 'a', 'a', 'b', 'c'], 'value': range( 6)})
  2. left1
 keyvalue
0a0
1b1
2a2
3a3
4b4
5c5

   
   
  1. right1 = pd.DataFrame({ 'group_val':[ 3.5, 7]},index = [ 'a', 'b'])
  2. right1
 group_val
a3.5
b7.0
pd.merge(left1,right1,left_on = 'key',right_index = True)
   
   
 keyvaluegroup_val
0a03.5
2a23.5
3a33.5
1b17.0
4b47.0

有上可知,left_on、right_on是指定表中非索引列为连接键,left_index、right_index是指定表中索引列为连接键,两者可以组合,是为了区分是否是索引列

  1. 两个表中的索引列都是连接键

   
   
  1. left2 = pd.DataFrame(np.arange( 6).reshape( 3, 2),index = [ 'a', 'b', 'e'],columns = [ '0hio', 'nevada'])
  2. right2 = pd.DataFrame(np.arange( 7, 15).reshape( 4, 2),index = [ 'b', 'c', 'd', 'e'],columns = [ 'misso', 'ala'])
  3. left2
 0hionevada
a01
b23
e45
right2
   
   
 missoala
b78
c910
d1112
e1314
pd.merge(left2,right2,left_index = True,right_index = True,how = 'outer')
   
   
 0hionevadamissoala
a0.01.0NaNNaN
b2.03.07.08.0
cNaNNaN9.010.0
dNaNNaN11.012.0
e4.05.013.014.0

3)轴向连接

在这里展示一种新的连接方法,对应于numpy的concatenate函数,pandas有concat函数


   
   
  1. #numpy
  2. arr =np.arange( 12).reshape( 3, 4)
arr
   
   

   
   
  1. array( [[ 0, 1, 2, 3],
  2. [ 4, 5, 6, 7],
  3. [ 8, 9, 10, 11]])
np.concatenate([arr,arr],axis = 1)#横轴连接块
   
   

   
   
  1. array( [[ 0, 1, 2, 3, 0, 1, 2, 3],
  2. [ 4, 5, 6, 7, 4, 5, 6, 7],
  3. [ 8, 9, 10, 11, 8, 9, 10, 11]])

1 concat函数参数表格

参数说明
objs参与连接的列表或字典,且列表或字典里的对象是pandas数据类型,唯一必须给定的参数
axis=0指明连接的轴向,0是纵轴,1是横轴,默认是0
join‘inner’(交集),‘outer’(并集),默认是‘outer’指明轴向索引的索引是交集还是并集
join_axis指明用于其他n-1条轴的索引(层次化索引,某个轴向有多个索引),不执行交并集
keys与连接对象有关的值,用于形成连接轴向上的层次化索引(外层索引),可以是任意值的列表或数组、元组数据、数组列表(如果将levels设置成多级数组的话)
levels指定用作层次化索引各级别(内层索引)上的索引,如果设置keys的话
names用于创建分层级别的名称,如果设置keys或levels的话
verify_integrity检查结果对象新轴上的重复情况,如果发横则引发异常,默认False,允许重复
ignore_index不保留连接轴上的索引,产生一组新索引range(total_length)

1.1 相同字段的表首尾相接

这里写图片描述


   
   
  1. # 现将表构成list,然后在作为concat的输入
  2. In [ 4]: frames = [df1, df2, df3]
  3. In [ 5]: result = pd.concat(frames)

要在相接的时候在加上一个层次的key来识别数据源自于哪张表,可以增加key参数

In [6]: result = pd.concat(frames, keys=['x', 'y', 'z'])
   
   

效果如下

这里写图片描述

1.2 横向表拼接(行对齐)

1.2.1 axis

当axis = 1的时候,concat就是行对齐,然后将不同列名称的两张表合并

In [9]: result = pd.concat([df1, df4], axis=1)
   
   

这里写图片描述

1.2.2 join

加上join参数的属性,如果为’inner’得到的是两表的交集,如果是outer,得到的是两表的并集。

In [10]: result = pd.concat([df1, df4], axis=1, join='inner')
   
   

这里写图片描述

1.2.3 join_axes

如果有join_axes的参数传入,可以指定根据那个轴来对齐数据 
例如根据df1表对齐数据,就会保留指定的df1表的轴,然后将df4的表与之拼接

In [11]: result = pd.concat([df1, df4], axis=1, join_axes=[df1.index])
   
   

这里写图片描述

1.3 append

append是series和dataframe的方法,使用它就是默认沿着列进行凭借(axis = 0,列对齐)
   
   
In [12]: result = df1.append(df2)
   
   

这里写图片描述

1.4 无视index的concat

如果两个表的index都没有实际含义,使用ignore_index参数,置true,合并的两个表就睡根据列字段对齐,然后合并。最后再重新整理一个新的index。 
这里写图片描述

1.5 合并的同时增加区分数据组的键

前面提到的keys参数可以用来给合并后的表增加key来区分不同的表数据来源

1.5.1 可以直接用key参数实现

In [27]: result = pd.concat(frames, keys=['x', 'y', 'z'])
   
   

这里写图片描述

1.5.2 传入字典来增加分组键


   
   
  1. In [ 28]: pieces = { 'x': df1, 'y': df2, 'z': df3}
  2. In [ 29]: result = pd .concat(pieces)

这里写图片描述

1.6 在dataframe中加入新的行

append方法可以将 series 和 字典就够的数据作为dataframe的新一行插入。 
这里写图片描述


   
   
  1. In [ 34]: s2 = pd.Series([ 'X0', 'X1', 'X2', 'X3'], index=[ 'A', 'B', 'C', 'D'])
  2. In [ 35]: result = df1.append(s2, ignore_index= True)

表格列字段不同的表合并

如果遇到两张表的列字段本来就不一样,但又想将两个表合并,其中无效的值用nan来表示。那么可以使用ignore_index来实现。
   
   

这里写图片描述


   
   
  1. In [ 36]: dicts = [{ 'A': 1, 'B': 2, 'C': 3, 'X': 4},
  2. ....: { 'A': 5, 'B': 6, 'C': 7, 'Y': 8}]
  3. ....:
  4. In [ 37]: result = df1.append(dicts, ignore_index= True)


数据规整化:合并、清理、过滤

pandas和python标准库提供了一整套高级、灵活的、高效的核心函数和算法将数据规整化为你想要的形式!

本篇博客主要介绍:

合并数据集:.merge()、.concat()等方法,类似于SQL或其他关系型数据库的连接操作。

合并数据集

1) merge 函数参数

参数说明
left参与合并的左侧DataFrame
right参与合并的右侧DataFrame
how连接方式:‘inner’(默认);还有,‘outer’、‘left’、‘right’
on用于连接的列名,必须同时存在于左右两个DataFrame对象中,如果位指定,则以left和right列名的交集作为连接键
left_on左侧DataFarme中用作连接键的列
right_on右侧DataFarme中用作连接键的列
left_index将左侧的行索引用作其连接键
right_index将右侧的行索引用作其连接键
sort根据连接键对合并后的数据进行排序,默认为True。有时在处理大数据集时,禁用该选项可获得更好的性能
suffixes字符串值元组,用于追加到重叠列名的末尾,默认为(‘_x’,‘_y’).例如,左右两个DataFrame对象都有‘data’,则结果中就会出现‘data_x’,‘data_y’
copy设置为False,可以在某些特殊情况下避免将数据复制到结果数据结构中。默认总是赋值

1、多对一的合并(一个表的连接键列有重复值,另一个表中的连接键没有重复值)


   
   
  1. import pandas as pd
  2. import numpy as np
  3. df1 = pd.DataFrame({ 'key':[ 'b', 'b', 'a', 'c', 'a', 'a', 'b'], 'data1': range( 7)})
  4. df1
 data1key
00b
11b
22a
33c
44a
55a
66b

   
   
  1. df2 = pd.DataFrame({ 'key':[ 'a', 'b', 'd'], 'data2':range( 3)})
  2. df2
 data2key
00a
11b
22d
pd.merge(df1,df2)#默认情况
   
   
 data1keydata2
00b1
11b1
26b1
32a0
44a0
55a0
df1.merge(df2)
   
   
 data1keydata2
00b1
11b1
26b1
32a0
44a0
55a0
df1.merge(df2,on = 'key',how = 'inner')#内连接,取交集
   
   
 data1keydata2
00b1
11b1
26b1
32a0
44a0
55a0
df1.merge(df2,on = 'key',how = 'outer')#外链接,取并集,并用nan填充
   
   
 data1keydata2
00.0b1.0
11.0b1.0
26.0b1.0
32.0a0.0
44.0a0.0
55.0a0.0
63.0cNaN
7NaNd2.0
df1.merge(df2,on = 'key',how = 'left')#左连接,左侧DataFrame取全部,右侧DataFrame取部分
   
   
 data1keydata2
00b1.0
11b1.0
22a0.0
33cNaN
44a0.0
55a0.0
66b1.0
df1.merge(df2,on = 'key',how = 'right')#右连接,右侧DataFrame取全部,左侧DataFrame取部分
   
   
 data1keydata2
00.0b1
11.0b1
26.0b1
32.0a0
44.0a0
55.0a0
6NaNd2

如果左右侧DataFrame的连接键列名不一致,但是取值有重叠,可使用left_on、right_on来指定左右连接键


   
   
  1. df3 = pd.DataFrame({ 'lkey':[ 'b', 'b', 'a', 'c', 'a', 'a', 'b'], 'data1': range( 7)})
  2. df3
 data1lkey
00b
11b
22a
33c
44a
55a
66b

   
   
  1. df4 = pd.DataFrame({ 'rkey':[ 'a', 'b', 'd'], 'data2':range( 3)})
  2. df4
 data2rkey
00a
11b
22d
df3.merge(df4,left_on = 'lkey',right_on = 'rkey',how = 'inner')
   
   
 data1lkeydata2rkey
00b1b
11b1b
26b1b
32a0a
44a0a
55a0a

2、多对多的合并(一个表的连接键列有重复值,另一个表中的连接键有重复值)


   
   
  1. df1 = pd.DataFrame({ 'key':[ 'b', 'b', 'a', 'c', 'a', 'a', 'b'], 'data1': range( 7)})
  2. df1
 data1key
00b
11b
22a
33c
44a
55a
66b

   
   
  1. df5 = pd.DataFrame({ 'key':[ 'a', 'b', 'a', 'b', 'b'], 'data2': range( 5)})
  2. df5
 data2key
00a
11b
22a
33b
44b
df1.merge(df5)
   
   
 data1keydata2
00b1
10b3
20b4
31b1
41b3
51b4
66b1
76b3
86b4
92a0
102a2
114a0
124a2
135a0
145a2

合并小结

1)默认情况下,会将两个表中相同列名作为连接键

2)多对多,会采用笛卡尔积形式链接(左表连接键有三个值‘1,3,5’,右表有两个值‘2,3’,则会形成,(1,2)(1,3)(3,1),(3,2)。。。6种组合)

3)存在多个连接键的处理


   
   
  1. left = pd.DataFrame({ 'key1':[ 'foo', 'foo', 'bar'], 'key2':[ 'one', 'one', 'two'], 'lval':[ 1, 2, 3]})
  2. right = pd.DataFrame({ 'key1':[ 'foo', 'foo', 'bar', 'bar'], 'key2':[ 'one', 'one', 'one', 'two'], 'rval':[ 4, 5, 6, 7]})
left
   
   
 key1key2lval
0fooone1
1fooone2
2bartwo3
right
   
   
 key1key2rval
0fooone4
1fooone5
2barone6
3bartwo7
pd.merge(left,right,on = ['key1','key2'],how = 'outer')
   
   
 key1key2lvalrval
0fooone1.04
1fooone1.05
2fooone2.04
3fooone2.05
4bartwo3.07
5baroneNaN6

1)连接键是多对多关系,应执行笛卡尔积形式

2)多列应看连接键值对是否一致

4)对连接表中非连接列的重复列名的处理

pd.merge(left,right,on = 'key1')
   
   
 key1key2_xlvalkey2_yrval
0fooone1one4
1fooone1one5
2fooone2one4
3fooone2one5
4bartwo3one6
5bartwo3two7
pd.merge(left,right,on = 'key1',suffixes = ('_left','_right'))
   
   
 key1key2_leftlvalkey2_rightrval
0fooone1one4
1fooone1one5
2fooone2one4
3fooone2one5
4bartwo3one6
5bartwo3two7

2)索引上的合并

当连接键位于索引中时,成为索引上的合并,可以通过merge函数,传入left_index、right_index来说明应该被索引的情况。

  1. 一表中连接键是索引列、另一表连接键是非索引列

   
   
  1. left1 = pd.DataFrame({ 'key':[ 'a', 'b', 'a', 'a', 'b', 'c'], 'value': range( 6)})
  2. left1
 keyvalue
0a0
1b1
2a2
3a3
4b4
5c5

   
   
  1. right1 = pd.DataFrame({ 'group_val':[ 3.5, 7]},index = [ 'a', 'b'])
  2. right1
 group_val
a3.5
b7.0
pd.merge(left1,right1,left_on = 'key',right_index = True)
   
   
 keyvaluegroup_val
0a03.5
2a23.5
3a33.5
1b17.0
4b47.0

有上可知,left_on、right_on是指定表中非索引列为连接键,left_index、right_index是指定表中索引列为连接键,两者可以组合,是为了区分是否是索引列

  1. 两个表中的索引列都是连接键

   
   
  1. left2 = pd.DataFrame(np.arange( 6).reshape( 3, 2),index = [ 'a', 'b', 'e'],columns = [ '0hio', 'nevada'])
  2. right2 = pd.DataFrame(np.arange( 7, 15).reshape( 4, 2),index = [ 'b', 'c', 'd', 'e'],columns = [ 'misso', 'ala'])
  3. left2
 0hionevada
a01
b23
e45
right2
   
   
 missoala
b78
c910
d1112
e1314
pd.merge(left2,right2,left_index = True,right_index = True,how = 'outer')
   
   
 0hionevadamissoala
a0.01.0NaNNaN
b2.03.07.08.0
cNaNNaN9.010.0
dNaNNaN11.012.0
e4.05.013.014.0

3)轴向连接

在这里展示一种新的连接方法,对应于numpy的concatenate函数,pandas有concat函数


   
   
  1. #numpy
  2. arr =np.arange( 12).reshape( 3, 4)
arr
   
   

   
   
  1. array( [[ 0, 1, 2, 3],
  2. [ 4, 5, 6, 7],
  3. [ 8, 9, 10, 11]])
np.concatenate([arr,arr],axis = 1)#横轴连接块
   
   

   
   
  1. array( [[ 0, 1, 2, 3, 0, 1, 2, 3],
  2. [ 4, 5, 6, 7, 4, 5, 6, 7],
  3. [ 8, 9, 10, 11, 8, 9, 10, 11]])

1 concat函数参数表格

参数说明
objs参与连接的列表或字典,且列表或字典里的对象是pandas数据类型,唯一必须给定的参数
axis=0指明连接的轴向,0是纵轴,1是横轴,默认是0
join‘inner’(交集),‘outer’(并集),默认是‘outer’指明轴向索引的索引是交集还是并集
join_axis指明用于其他n-1条轴的索引(层次化索引,某个轴向有多个索引),不执行交并集
keys与连接对象有关的值,用于形成连接轴向上的层次化索引(外层索引),可以是任意值的列表或数组、元组数据、数组列表(如果将levels设置成多级数组的话)
levels指定用作层次化索引各级别(内层索引)上的索引,如果设置keys的话
names用于创建分层级别的名称,如果设置keys或levels的话
verify_integrity检查结果对象新轴上的重复情况,如果发横则引发异常,默认False,允许重复
ignore_index不保留连接轴上的索引,产生一组新索引range(total_length)

1.1 相同字段的表首尾相接

这里写图片描述


   
   
  1. # 现将表构成list,然后在作为concat的输入
  2. In [ 4]: frames = [df1, df2, df3]
  3. In [ 5]: result = pd.concat(frames)

要在相接的时候在加上一个层次的key来识别数据源自于哪张表,可以增加key参数

In [6]: result = pd.concat(frames, keys=['x', 'y', 'z'])
   
   

效果如下

这里写图片描述

1.2 横向表拼接(行对齐)

1.2.1 axis

当axis = 1的时候,concat就是行对齐,然后将不同列名称的两张表合并

In [9]: result = pd.concat([df1, df4], axis=1)
   
   

这里写图片描述

1.2.2 join

加上join参数的属性,如果为’inner’得到的是两表的交集,如果是outer,得到的是两表的并集。

In [10]: result = pd.concat([df1, df4], axis=1, join='inner')
   
   

这里写图片描述

1.2.3 join_axes

如果有join_axes的参数传入,可以指定根据那个轴来对齐数据 
例如根据df1表对齐数据,就会保留指定的df1表的轴,然后将df4的表与之拼接

In [11]: result = pd.concat([df1, df4], axis=1, join_axes=[df1.index])
   
   

这里写图片描述

1.3 append

append是series和dataframe的方法,使用它就是默认沿着列进行凭借(axis = 0,列对齐)
   
   
In [12]: result = df1.append(df2)
   
   

这里写图片描述

1.4 无视index的concat

如果两个表的index都没有实际含义,使用ignore_index参数,置true,合并的两个表就睡根据列字段对齐,然后合并。最后再重新整理一个新的index。 
这里写图片描述

1.5 合并的同时增加区分数据组的键

前面提到的keys参数可以用来给合并后的表增加key来区分不同的表数据来源

1.5.1 可以直接用key参数实现

In [27]: result = pd.concat(frames, keys=['x', 'y', 'z'])
   
   

这里写图片描述

1.5.2 传入字典来增加分组键


   
   
  1. In [ 28]: pieces = { 'x': df1, 'y': df2, 'z': df3}
  2. In [ 29]: result = pd .concat(pieces)

这里写图片描述

1.6 在dataframe中加入新的行

append方法可以将 series 和 字典就够的数据作为dataframe的新一行插入。 
这里写图片描述


   
   
  1. In [ 34]: s2 = pd.Series([ 'X0', 'X1', 'X2', 'X3'], index=[ 'A', 'B', 'C', 'D'])
  2. In [ 35]: result = df1.append(s2, ignore_index= True)

表格列字段不同的表合并

如果遇到两张表的列字段本来就不一样,但又想将两个表合并,其中无效的值用nan来表示。那么可以使用ignore_index来实现。
   
   

这里写图片描述


   
   
  1. In [ 36]: dicts = [{ 'A': 1, 'B': 2, 'C': 3, 'X': 4},
  2. ....: { 'A': 5, 'B': 6, 'C': 7, 'Y': 8}]
  3. ....:
  4. In [ 37]: result = df1.append(dicts, ignore_index= True)


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值