- 0
- 이니스프리
- 조회 수 1420
안녕하세요?
아미나의 '티스탁' 님께서 정리하신 명언 엑셀파일을
PHP 등에서 사용하기 위해 CSV 파일로 변환하는 스크립트입니다.
http://amina.co.kr/bbs/board.php?bo_table=skin_member&wr_id=4169
무료로 제공되고 있고, 열어보면 아시겠지만 굉장히 많은 명언이 잘 정리되어 있어요 ^^
XLS 파일로 저장되어 있는데 openpyxl 라이브러리로 읽으려면 우선 엑셀에서 xlsx 파일로 변환해야 합니다.
스크립트를 실행하면 원하는 구간의 B열에 담긴 명언만 추출해서 CSV 파일로 변환해줍니다.
delimiter로는 엔터를 사용했는데 작업에 따라서는 ';'가 더 편할 수도 있겠네요.
PHP에서는 fgetcsv() 함수로 불러오면 됩니다.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | import openpyxl, csv wb = openpyxl.load_workbook( '파일명.xlsx' ) ws = wb.active start_row = 시작 열 end_row = 마지막 열 mylist = [] count = 1 for column in ws[ 'B' ]: if count > = start_row and count < = end_row: mylist.append(column.value) count + = 1 with open ( "파일명.csv" , "w" ) as f: wr = csv.writer(f, delimiter = '\n' ) wr.writerow(mylist) |
openpyxl 라이브러리도 업데이트가 여러 번 진행되면서 꽤 많은 부분이 변했네요.
공식문서를 확인해보니 대체로 이전보다 간결하게 사용할 수 있는 방법으로 바뀐 것 같네요.
그래서 현재의 라이브러리는 "파이썬 프로그래밍으로 지루한 작업 자동화하기" 책에 실린 것과 차이가 조금 있더군요.
이 스크립트는 openpyxl 최신 버전을 기준으로 작성해서 구 버전에서는 돌아가지 않을 것 같네요.
그럼 편안한 저녁 되시고 무더위에 항상 건강하세요!
굿밤 되세요 ^^
+) 인코딩의 변환이 필요한 경우 아래 스크립트를 활용하시면 됩니다.
1 2 3 4 5 6 7 | before = codecs. open ( '변환전파일명' , 'r' , encoding = 'euc_kr' ) after = codecs. open ( '변환후파일명' , 'w' , encoding = 'utf-8' ) for line in before: line = line.replace(u '\xa0' , ' ' ) out.write(line) before.close() after.close() |
작성자
댓글 0
권한이 없습니다.