python实现两个文件合并功能


Posted in Python onApril 01, 2018

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

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

python实现两个文件合并功能

python实现两个文件合并功能

分析思路:

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

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

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

流程图如下:

python实现两个文件合并功能

代码如下:

"""
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 = '\t'.join([file1_name[i],file1_tel[i],file2_email[j]])
   s += '\n'
  else:
   s = '\t'.join([file1_name[i],file1_tel[i],str("----")])
   s += '\n'
  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 = '\t'.join([file2_name[i],str('----'),file2_email[i]])
   s += '\n'
  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()

关键点:

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
java直接调用python脚本的例子
Feb 16 Python
Python中的map()函数和reduce()函数的用法
Apr 27 Python
python的else子句使用指南
Feb 27 Python
利用python程序帮大家清理windows垃圾
Jan 15 Python
python爬虫_微信公众号推送信息爬取的实例
Oct 23 Python
django1.11.1 models 数据库同步方法
May 30 Python
对python 读取线的shp文件实例详解
Dec 22 Python
树莓派+摄像头实现对移动物体的检测
Jun 22 Python
如何基于python实现脚本加密
Dec 28 Python
Tensorflow 实现将图像与标签数据转化为tfRecord文件
Feb 17 Python
如何基于python实现年会抽奖工具
Oct 20 Python
几款好用的python工具库(小结)
Oct 20 Python
Python中一行和多行import模块问题
Apr 01 #Python
Python对List中的元素排序的方法
Apr 01 #Python
Python去除、替换字符串空格的处理方法
Apr 01 #Python
利用scrapy将爬到的数据保存到mysql(防止重复)
Mar 31 #Python
python 通过xml获取测试节点和属性的实例
Mar 31 #Python
Python Xml文件添加字节属性的方法
Mar 31 #Python
Python简单生成随机数的方法示例
Mar 31 #Python
You might like
PHP伪静态写法附代码
2008/06/20 PHP
php strrpos()与strripos()函数
2013/08/31 PHP
PHP编译安装中遇到的两个错误和解决方法
2014/08/20 PHP
thinkphp5.1框架中容器(Container)和门面(Facade)的实现方法分析
2019/08/05 PHP
js动态为代码着色显示行号
2013/05/29 Javascript
JavaScript操纵窗口的方法小结
2013/06/28 Javascript
js函数调用的方式
2014/05/06 Javascript
js获取url中"?"后面的字串方法
2014/05/15 Javascript
JavaScript实现16进制颜色值转RGB的方法
2015/02/09 Javascript
JavaScript 中 avalon绑定属性总结
2016/10/19 Javascript
jQuery快速实现商品数量加减的方法
2017/02/06 Javascript
jQuery UI Grid 模态框中的表格实例代码
2017/04/01 jQuery
webpack里使用jquery.mCustomScrollbar插件的方法
2018/05/30 jQuery
angular4中引入echarts的方法示例
2019/01/29 Javascript
微信小程序实现分页加载效果
2020/11/19 Javascript
微信小程序之高德地图多点路线规划过程示例详解
2021/01/18 Javascript
python通过shutil实现快速文件复制的方法
2015/03/14 Python
Python 实现「食行生鲜」签到领积分功能
2018/09/26 Python
Python基于聚类算法实现密度聚类(DBSCAN)计算【测试可用】
2018/12/26 Python
python输出决策树图形的例子
2019/08/09 Python
Python socket非阻塞模块应用示例
2019/09/12 Python
创建Shapefile文件并写入数据的例子
2019/11/26 Python
关于numpy.where()函数 返回值的解释
2019/12/06 Python
使用bandit对目标python代码进行安全函数扫描的案例分析
2021/01/27 Python
CSS3中各种颜色属性的使用教程
2016/05/17 HTML / CSS
美国半成品食材配送服务商:Home Chef
2018/01/25 全球购物
Servlet方面面试题
2016/09/28 面试题
土木工程应届生自荐信
2013/09/24 职场文书
《威尼斯的小艇》教学反思
2014/02/17 职场文书
工厂仓管员岗位职责范本
2014/07/17 职场文书
群众路线自我剖析材料
2014/10/08 职场文书
奖学金个人总结
2015/03/04 职场文书
2016幼儿园新学期寄语
2015/12/03 职场文书
2016年教师党员承诺书范文
2016/03/24 职场文书
使用pytorch实现线性回归
2021/04/11 Python
Golang之sync.Pool使用详解
2021/05/06 Golang