• 목록
  • 아래로
  • 위로

파이썬으로 스크립트를 작성하다보면 텍스트 파일을 읽어서 각 행을 리스트 변수에 넣어야 하는 경우가 종종 있죠.

 

이하 filename.txt라는 파일의 각 행을 (line이란 변수에 넣어서) 최종적으로 list_file이란 리스트 변수에 대입하는 것으로 

 

파일명과 변수명을 통일하여 설명해 보겠습니다 ^^

 

물론 다른 라이브러리를 사용하는 방법도 가능하지만 경우의 수가 너무 많아지니 배제할게요.

 

 

 

1. 다음과 같이 파일 객체를 readlines로 한 줄씩 읽고 각 줄의 끝에 붙은 '\n'을 지워주는 방법을 생각해볼 수 있습니다.

with open('filename.txt', 'r') as f:
    list_file = f.readlines()
list_file = [line.rstrip('\n') for line in list_file] 

 

다만 이 방법은 빅데이터처럼 아주 큰 파일을 다룰 때 readlines()가 효율적이지 않고 

 

때로는 메모리 관련 에러를 유발할 소지가 있다는 문제점이 있죠.

 

 

 

2. 파일 객체를 한 줄씩 배열로 더 해주는 방법도 생각해 볼 수 있습니다.

with open('filename.txt', 'r') as f:
    list_file = []
    for line in f:
        list_file.append(line)

 

append()가 속도가 빠른 것은 아니지만 이 방법이 1번보다 조금 더 효율적이고 안정적이라고 볼 수 있겠네요.

 

 

 

3. 심플하게 파일 객체를 '\n'으로 나눠서 각 요소를 리스트에 넣는 방법도 있습니다.

list_file = open('filename.txt', 'r').read().split('\n')

 

close()를 하지 않아도 대개의 경우 별다른 문제가 발생하지 않지만 모든 경우에 그런 것은 아니죠.

 

 

 

4. 다음과 같이 List Comprehension 한 줄로 처리하는 방법도 있습니다.

list_file = [line.rstrip('\n') for line in open('filename.txt', 'r')]

 

파이썬다운 문법이긴 한데 3번과 같은 문제점이 있기는 합니다.

 

 

 

5. '\n' 단위로 요소를 리스트에 넣되 '\n'을 ''로 바꿔주는 함수인 splitlines()를 이용할 수도 있습니다.

with open('filename.txt', 'r') as f:
    data = f.read()
file_list = data.splitlines()

 

제가 보기에는 특별한 단점은 없는 것 같네요. 솔직히 어떤 문제점이 있는지는 잘 모르겠습니다 ㅠㅠ

 

 

 

원래 파이썬은 '가장 아름다운 하나의 답이 존재한다'라는 철학을 베이스로 하는데 

 

저도 파이썬에 대해 잘 알지도 못하면서 작성하다보니 중구난방식의 글이 되어버렸네요 ㅠㅠ

 

스포어의 파이썬 고수님들께서 보시기엔 헛소리를 늘어놓는 것처럼 보일 수도 있겠네요.

 

그럼 굿밤 되세요~!

작성자
이니스프리 119 Lv. (0%) 1901810/115200000EXP

Make StudyForUs Great Again!

 

CSVpuymXAAAVVpd.jpg

댓글 0

권한이 없습니다.
번호 제목 글쓴이 날짜 조회 수
공지 [작업 완료] 설 명절 맞이 서버 업데이트 안내 3 마스터 마스터 24.02.11.17:21 687
공지 [중요] 호스팅 만료와 관련하여 일부 수칙이 변경됩니다. 4 마스터 마스터 23.01.14.02:23 4367
506 [프린터/복합기] 캐논 복합기 MF6XX ID 및 PIN 1 이니스프리 이니스프리 21.08.16.09:19 505
505 [Python] Naver Login with requests 1 image Hanam09 Hanam09 21.07.17.01:48 2856
504 [Python] 엑셀 파일에 암호 설정 (Set password for Excel file using Python) 3 image 이니스프리 이니스프리 21.07.09.21:21 1196
503 [Python] 구버전 KeyCaptcha 정답 좌표 찾기 image 네모 네모 21.07.09.02:46 157
502 [Python] 패스워드 걸린 PDF 파일을 오픈하여 패스워드를 삭제한 채로 저장하기 이니스프리 이니스프리 21.07.08.18:26 590
501 [Python] 구글 뉴스 RSS 파싱 2 이니스프리 이니스프리 21.07.04.13:49 226
500 [Python] 이미지 파일의 Exif 정보 삭제하기 (+ 식빵자세 산냥이) image 이니스프리 이니스프리 21.07.03.13:42 262
499 [Python] PDF2image 모듈이 실행되지 않을 때 이니스프리 이니스프리 21.06.23.20:36 2615
498 유료 VPN 선택과 관련하여 참고할 웹 문서! 2 이니스프리 이니스프리 21.06.08.19:28 248
497 [Python] 영어로 표기된 날짜를 숫자로 변환 이니스프리 이니스프리 21.05.30.11:39 1072
496 [Python] Google Trend의 '최근 인기 검색어' 크롤링 3 이니스프리 이니스프리 21.05.02.12:24 486
495 [Python] for 문에 두 개의 리스트를 넣고 enumerate를 사용하는 방법 이니스프리 이니스프리 21.05.01.21:01 219
494 [Python] 입력받은 연도가 윤년이 아니면 그보다 가장 가까운 과거의 윤년을 출력하기 8 이니스프리 이니스프리 21.04.19.20:23 437
493 [Javascript] 이미지 업로드 전 가로x세로 사이즈를 확인하여 지정된 크기 이상인 경우 alert 띄우는 스크립트 이니스프리 이니스프리 21.04.17.21:28 123
492 [HTML] 특정 사이트의 파비콘을 다운로드 받는 방법 이니스프리 이니스프리 21.04.16.22:02 261
491 [Javascript] 값을 이용하여 배열의 요소를 삭제하는 방법 이니스프리 이니스프리 21.04.13.22:10 97
490 [Gnuboard] DB 테이블 중 g5_board_file에 대하여 이니스프리 이니스프리 21.04.11.16:25 394
489 [Windows] Windows 업데이트 원천 방지하기 5 image Seia Seia 21.04.10.07:10 246
488 [Docker] Docker 다시 알고 사용하기 Seia Seia 21.04.10.07:04 167
487 [미디어위키/리버티 스킨] 모바일 환경에서 가로로 긴 표가 짤리는 현상 개선하기(스크롤 구현) image 가온이 가온이 21.04.09.20:07 219