• 목록
  • 아래로
  • 위로

안녕하세요?


아미나의 '티스탁' 님께서 정리하신 명언 엑셀파일을 


PHP 등에서 사용하기 위해 CSV 파일로 변환하는 스크립트입니다.


http://amina.co.kr/bbs/board.php?bo_table=skin_member&wr_id=4169


무료로 제공되고 있고, 열어보면 아시겠지만 굉장히 많은 명언이 잘 정리되어 있어요 ^^



XLS 파일로 저장되어 있는데 openpyxl 라이브러리로 읽으려면 우선 엑셀에서 xlsx 파일로 변환해야 합니다.


스크립트를 실행하면 원하는 구간의 B열에 담긴 명언만 추출해서 CSV 파일로 변환해줍니다.


delimiter로는 엔터를 사용했는데 작업에 따라서는 ';'가 더 편할 수도 있겠네요.


PHP에서는 fgetcsv() 함수로 불러오면 됩니다.



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 최신 버전을 기준으로 작성해서 구 버전에서는 돌아가지 않을 것 같네요.



그럼 편안한 저녁 되시고 무더위에 항상 건강하세요!


굿밤 되세요 ^^



+) 인코딩의 변환이 필요한 경우 아래 스크립트를 활용하시면 됩니다.


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()


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

Make StudyForUs Great Again!

 

CSVpuymXAAAVVpd.jpg

댓글 0

권한이 없습니다.
번호 제목 글쓴이 날짜 조회 수
공지 [중요공지] 추석 맞이 서버 업데이트 안내 5 마스터 마스터 25.10.09.02:20 78631
공지 [중요] 호스팅 만료와 관련하여 일부 수칙이 변경됩니다. 7 마스터 마스터 23.01.14.02:23 372088
552 일부 GIF 파일을 ImageMagick으로 처리 시 이미지가 깨지는 경우 해결법 image 제르엘 제르엘 25.05.18.02:25 1477
551 [Python] installing Geopandas in Windows (Trouble shooting) 1 이니스프리 이니스프리 24.10.25.20:10 1498
550 [Nextcloud] 프로세스가 kill 되는 문제에 관한 Troubleshooting 3 이니스프리 이니스프리 24.09.30.19:53 1802
549 [펌] Contabo VPS 관련 최근 정보글 image 이니스프리 이니스프리 24.09.29.21:11 1048
548 [Python] PDF 파일을 특정 페이지를 기준으로 두 개로 나누기 이니스프리 이니스프리 24.08.11.20:27 1681
547 [Python] Youtube API를 사용하지 않고 특정 채널의 모든 비디오 URL을 가져오기 이니스프리 이니스프리 24.06.09.22:12 1419
546 HDMI 단자의 QHD 출력을 정식으로 지원하지 않는 NVIDIA 그래픽 카드로 QHD 60 Hz 해상도 출력하기 2 image 제르엘 제르엘 24.06.09.17:45 2287
545 [Python] cannot import name 'TypeAliasType' from 'typing_extensions' 에러 대응방법 이니스프리 이니스프리 24.06.01.23:54 1151
544 [VSCode] 1개의 OS에 VSCode 여러 개를 설치 및 구동하기 이니스프리 이니스프리 24.05.26.05:09 1156
543 [Python] 리스트에 중복된 원소가 있는지 확인하는 함수 이니스프리 이니스프리 24.05.22.20:21 1289
542 [Python] random 함수가 계속하여 동일한 결과를 출력할 때 해결방법 이니스프리 이니스프리 24.05.15.19:32 1555
541 트래픽 절감 관련 모 커뮤니티 사이트의 회의 결과 이니스프리 이니스프리 24.05.15.16:51 1390
540 [Python] SSL: CERTIFICATE_VERIFY_FAILED에 대한 대처 방법 (2) 이니스프리 이니스프리 24.05.05.21:04 1340
539 [KT] 오피스넷 가정 설치 관련 이니스프리 이니스프리 24.05.05.00:28 1250
538 [Python] 쿠팡 크롤링할 때 소소한 팁 이니스프리 이니스프리 24.05.02.21:50 1184
537 [Python] dictionary 2개의 평균을 구하여 내림차순 정렬하기 이니스프리 이니스프리 24.04.21.17:29 1109
536 [Python] 독일어, 스페인어, 체코어 등 철자를 영문 알파벳으로 전환하기 이니스프리 이니스프리 24.04.21.17:15 1054
535 [Python] Tabulate 모듈로 작성한 테이블을 파일로 저장할 때 에러가 발생하는 경우 이니스프리 이니스프리 24.04.20.23:45 939
534 [Python] 변수의 이름을 반환하는 함수 이니스프리 이니스프리 24.04.20.23:29 1171
533 [Python] Table을 쉽게 만들어주는 모듈x2 이니스프리 이니스프리 24.04.18.22:04 829