파이썬 관련 질문입니다.

음 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년 전 조회 1,998
11년 전 조회 1,615
11년 전 조회 1,629
11년 전 조회 2,103
11년 전 조회 2,157
11년 전 조회 2,185
11년 전 조회 2,203
11년 전 조회 1,850
11년 전 조회 1,920
11년 전 조회 4,714
11년 전 조회 2,567
11년 전 조회 1,486
11년 전 조회 1,915
11년 전 조회 1,766
11년 전 조회 3,128
11년 전 조회 1,653
11년 전 조회 1,798
11년 전 조회 1,524
11년 전 조회 1,912
11년 전 조회 1,662
11년 전 조회 1,937
11년 전 조회 2,673
11년 전 조회 1,530
11년 전 조회 1,521
11년 전 조회 2,621
11년 전 조회 2,402
11년 전 조회 2,335
11년 전 조회 1,719
11년 전 조회 2,457
11년 전 조회 1,995
11년 전 조회 1,862
11년 전 조회 2,076
11년 전 조회 2,206
11년 전 조회 2,286
11년 전 조회 2,222
11년 전 조회 4,966
11년 전 조회 3,915
11년 전 조회 1,969
11년 전 조회 2,455
11년 전 조회 6,066
11년 전 조회 2,932
11년 전 조회 2,267
11년 전 조회 1,937
11년 전 조회 2,497
11년 전 조회 2,495
11년 전 조회 2,169
11년 전 조회 1,693
11년 전 조회 1,922
11년 전 조회 1,794
11년 전 조회 2,094
11년 전 조회 2,527
11년 전 조회 2,527
11년 전 조회 1,753
11년 전 조회 2,398
11년 전 조회 2,098
11년 전 조회 1,854
11년 전 조회 5,989
11년 전 조회 5,528
11년 전 조회 2,070
11년 전 조회 5,374
11년 전 조회 4,939
11년 전 조회 5,356
11년 전 조회 6,223
11년 전 조회 5,892
11년 전 조회 5,420
11년 전 조회 1,933
11년 전 조회 6,808
11년 전 조회 2,666
11년 전 조회 2,157
11년 전 조회 4,138
11년 전 조회 2,107
11년 전 조회 3,808
11년 전 조회 3,398
11년 전 조회 2,567
11년 전 조회 2,789
11년 전 조회 2,112
11년 전 조회 3,275
11년 전 조회 2,066
11년 전 조회 6,599
11년 전 조회 3,441
11년 전 조회 4,520
11년 전 조회 2,138
11년 전 조회 2,307
11년 전 조회 2,200
11년 전 조회 2,766
11년 전 조회 2,131
11년 전 조회 2,759
11년 전 조회 5,424
11년 전 조회 3,240
11년 전 조회 3,186
11년 전 조회 7,152
11년 전 조회 3,086
11년 전 조회 3,976
11년 전 조회 3,585
11년 전 조회 2,228
11년 전 조회 4,363
11년 전 조회 3,698
11년 전 조회 7,070
11년 전 조회 4,690
11년 전 조회 3,155