用python實現兩個文本合並


一段時間前在網上看到一段面試題,要求如下:

employee文件中記錄了工號和姓名

    cat employee.txt:    

    100 Jason Smith    

    200 John Doe    

    300 Sanjay Gupta    

    400 Ashok Sharma

bonus文件中記錄工號和工資

    cat bonus.txt:    

    100 $5,000    

    200 $500    

    300 $3,000    

    400 $1,250

要求把兩個文件合並並輸出如下, 處理結果:

    400 ashok sharma $1,250    

    100 jason smith  $5,000    

    200 john doe  $500    

    300 sanjay gupta  $3,000

 

這個應該是要求用shell來寫的,但我的shell功底不怎么樣,就用python來實現了

注意,按題目的意思,在輸出文件中還需要按照姓名首字母來排序的

 1 #! /usr/bin/env python
 2 #coding=utf-8
 3 fp01 = open("bonus.txt", "r")
 4 a = []
 5 for line01 in fp01:
 6     a.append(line01)
 7 
 8 fp02 = open("employee.txt", "r")
 9 
10 fc02 = sorted(fp02, key = lambda x:x.split()[1])
11 
12 for line02 in fc02:
13     i = 0
14     while line02.split()[0]!=a[i].split()[0]:
15         i += 1
16     print "%s %s %s %s" % (line02.split()[0], line02.split()[1], line02.split()[2], a[i].split()[1])
17 
18 fp01.close()
19 fp02.close()

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM