파이썬 관련 질문입니다.

음 input1.txt 파일과 input2.txt 파일이 있는데요

 

input1.txt ------------------

chr1     a1     b1     c1

chr2     a2     b2     c2

chr3     a3     b3     c3

   .         .        .        .

   .         .        .        .

chr10   a10    b10   c10

--------------------------

 

 

input2.txt ------------------

chr1     d1     e1     f1

chr11   d2     e2     f2

chr2     d3     e3     f3

chr22   d4     e4     f4

. ...

    .        .        .       .

chr55   d10   e10   f10

---------------------------

 

각 파일의 내용은 이렇습니다.

 

제가 하고자 하는 작업은

 

두개의 파일의 배열[0]값을 서로 비교해서

같은값만을 출력하고 나머지

input1의 배열[1]과, 위에서 출력한 값에 해당하는 input2의 배열 [2],[3]을 차례대로 출력하고자 하는것인데요.

 

그러니까

 

output ---------------------------

chr1     a1     e1     f1

chr2     a2     e3     f3

chr3     a3     e5     f5

... .

   .         .        .       .

chr10   a10    e10   f10

---------------------------------

 

결과는 이렇게 나와야겠죠

 

 

 

이거는 제가 해본건데요.

그냥 출력하는것밖에 못했습니다..

---------------------------------

f=open("input1.txt")

q=open("input2.txt')

 

for line in f:

           index1=line.strip().split("     ");

for line in q:

           index2=line.strip().split("     ");

 

           print index1[0], index1[1],index2[0],index2[3];

 

f.close();

------------------------------------

 

if문을 써서 index1[0] 값과 index2[0]값을 비교해서

같으면 같은값만 출력하게하면 될거같은데..... 잘모르겠네요

 

어떻게 해야될까요??

 

고수분들의 도움 부탁드립니다..

 

 

|

댓글 2개

방법은 여러가지가 있는데, 간단히 이런 식으로 해볼 수 있겠죠.

def table(lines):
def f(x): return (x[0], x[1:])
return dict(f(line.split()) for line in lines)

data1 = table(open('input1.txt').readlines())
data2 = table(open('input2.txt').readlines())

for key in sorted(set(data1) & set(data2)):
print key, data1[key][0], data2[key][1], data2[key][2]
감사합니다 !!
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
11년 전 조회 2,021
11년 전 조회 1,633
11년 전 조회 1,653
11년 전 조회 2,122
11년 전 조회 2,176
11년 전 조회 2,211
11년 전 조회 2,217
11년 전 조회 1,871
11년 전 조회 1,944
11년 전 조회 4,747
11년 전 조회 2,585
11년 전 조회 1,501
11년 전 조회 1,939
11년 전 조회 1,778
11년 전 조회 3,146
11년 전 조회 1,674
11년 전 조회 1,825
11년 전 조회 1,550
11년 전 조회 1,934
11년 전 조회 1,682
11년 전 조회 1,960
11년 전 조회 2,698
11년 전 조회 1,556
11년 전 조회 1,553
11년 전 조회 2,645
11년 전 조회 2,438
11년 전 조회 2,358
11년 전 조회 1,751
11년 전 조회 2,473
11년 전 조회 2,017
11년 전 조회 1,882
11년 전 조회 2,097
11년 전 조회 2,229
11년 전 조회 2,312
11년 전 조회 2,245
11년 전 조회 4,989
11년 전 조회 3,930
11년 전 조회 1,997
11년 전 조회 2,475
11년 전 조회 6,079
11년 전 조회 2,955
11년 전 조회 2,287
11년 전 조회 1,959
11년 전 조회 2,516
11년 전 조회 2,518
11년 전 조회 2,188
11년 전 조회 1,711
11년 전 조회 1,938
11년 전 조회 1,812
11년 전 조회 2,107
11년 전 조회 2,552
11년 전 조회 2,553
11년 전 조회 1,768
11년 전 조회 2,426
11년 전 조회 2,111
11년 전 조회 1,868
11년 전 조회 6,006
11년 전 조회 5,547
11년 전 조회 2,092
11년 전 조회 5,398
11년 전 조회 4,964
11년 전 조회 5,379
11년 전 조회 6,244
11년 전 조회 5,913
11년 전 조회 5,437
11년 전 조회 1,954
11년 전 조회 6,831
11년 전 조회 2,686
11년 전 조회 2,174
11년 전 조회 4,163
11년 전 조회 2,137
11년 전 조회 3,826
11년 전 조회 3,418
11년 전 조회 2,589
11년 전 조회 2,808
11년 전 조회 2,135
11년 전 조회 3,297
11년 전 조회 2,090
11년 전 조회 6,623
11년 전 조회 3,456
11년 전 조회 4,544
11년 전 조회 2,171
11년 전 조회 2,335
11년 전 조회 2,225
11년 전 조회 2,786
11년 전 조회 2,157
11년 전 조회 2,793
11년 전 조회 5,451
11년 전 조회 3,260
11년 전 조회 3,208
11년 전 조회 7,182
11년 전 조회 3,121
11년 전 조회 3,996
11년 전 조회 3,609
11년 전 조회 2,255
11년 전 조회 4,382
11년 전 조회 3,722
11년 전 조회 7,097
11년 전 조회 4,717
11년 전 조회 3,174