python怎么把两个pd合在一起

发布网友 发布时间:2022-04-20 15:53

我来回答

2个回答

懂视网 时间:2022-05-10 11:16

这篇文章主要为大家详细介绍了python实现两个文件合并功能,一个简单的文件合并程序,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文将会分析一个文件合并的程序,并指出在合并文件过程中需要注意的问题。

下面是需要合并的文件示例:


分析思路:

要将两个文件合并,首先要将文件读到内存中,成为列表。再将列表分割,按照类别将数据分开存储,即姓名、电话、邮箱。通过遍历列表1,依次与列表2比较,如果二者有重合的人,那么直接利用 .join([ ])姓名电话邮箱合并到一行,保存到另外一个列表变量里面。二者不重合的人,说明只有列表1中才有,故将此人的邮箱信息用str(‘—–')代替。

经过这次遍历之后,列表1中所有的人和列表2中与列表1中重复的人,都重新整合到了新的列表变量里面。接下来还需要把列表2中特有的人,添加到新的列表变量中。方法是遍历列表2,把与列表1不重合的人取出来保存。

最后要将新的列表变量中的数据写入到新的文件中,并关闭所有文件。

流程图如下:

代码如下:


"""
Created on Fri Aug 4 12:59:36 2017

@author: 13323
"""
# This program can combine two or more files into one file.
def main():
 #firstly open the files
 data1 = open("test_3.txt","rb")
 data2 = open("test_4.txt","rb")

 # read the data in file into list
 data1.readline() #only read one line, skip the first line
 data2.readline() #only read one line, skip the first line
 file1 = data1.readlines() #read all variable into list file1 
 file2 = data2.readlines() #read all variable into list file2
 #print(file1)

 #define particular list to store variable
 file1_name = []
 file1_tel = []
 file2_name = []
 file2_email = []
 #file3 = []

 #split file1 into two part
 for line in file1:
 element = line.split() #line.split(); devide by ' '
 file1_name.append(str(element[0].decode('gbk')))
 file1_tel.append(str(element[1].decode('gbk')))

 #split file2 into two part
 for line in file2:
 element = line.split()
 file2_name.append(str(element[0].decode('gbk')))
 file2_email.append(str(element[1].decode('gbk')))

 # pick up the name in the file1 same as the name in the file2 and combine 
 file3 = []
 for i in range(len(file1_name)):
 s = ''
 if file1_name[i] in file2_name:
 j = file2_name.index(file1_name[i])
 s = '	'.join([file1_name[i],file1_tel[i],file2_email[j]])
 s += '
'
 else:
 s = '	'.join([file1_name[i],file1_tel[i],str("----")])
 s += '
'
 file3.append(s)

 #pick up the name in the file1 doesn't same as the name in the file2 
 for i in range(len(file2_name)):
 s = ''
 if file2_name[i] not in file1_name:
 s = '	'.join([file2_name[i],str('----'),file2_email[i]])
 s += '
'
 file3.append(s)

 #write the data into file3 
 data3 = open("test_5.txt","w")
 data3.writelines(file3)

 #close the file
 data1.close()
 data2.close()
 data3.close()

main()


关键点:

编码与解码
列表合并与拆解

热心网友 时间:2022-05-10 08:24

python把两个pd合在一起:for lineA in open('a.txt','r'):a.append(lineA)for lineB in open('b.txt','r'):b.append(lineB)。

#例子:合并a.txt、b.txt、c.txt合并成d.txt文件,#文件列表,遍于读取flist = ['a.txt','b.txt','c.txt']#要写入的文件ofile = open('d.txt', 'w')#遍历读取所有文件,并写入到输出文件。

语言特点:

简单:Python是一种代表简单主义思想的语言。阅读一个良好的Python程序就感觉像是在读英语一样。它使你能够专注于解决问题而不是去搞明白语言本身。

易学:Python极其容易上手,因为Python有极其简单的说明文档。

易读、易维护:风格清晰划一、强制缩进。

速度快:Python 的底层是用 C 语言写的,很多标准库和第三方库也都是用 C 写的,运行速度非常快。

免费、开源:Python是FLOSS(自由/开放源码软件)之一。使用者可以自由地发布这个软件的拷贝、阅读它的源代码、对它做改动、把它的一部分用于新的自由软件中。FLOSS是基于一个团体分享知识的概念。

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com