• 목록
  • 아래로
  • 위로

안녕하세요?


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


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. (0%) 2068920/115200000EXP

Make StudyForUs Great Again!

 

CSVpuymXAAAVVpd.jpg

댓글 0

권한이 없습니다.
번호 제목 글쓴이 날짜 조회 수
공지 [작업 완료] 설 명절 맞이 서버 업데이트 안내 3 마스터 마스터 24.02.11.17:21 1010
공지 [중요] 호스팅 만료와 관련하여 일부 수칙이 변경됩니다. 4 마스터 마스터 23.01.14.02:23 4688
332 [할인정보] 이니스프리 2/15-2/18 올해 첫 빅 세일! (최대 50% 할인) 2 이니스프리 이니스프리 17.02.15.19:51 270
331 [Python] 두 개의 변수를 하나의 for문에서 돌리기 - zip() 활용 이니스프리 이니스프리 20.06.16.14:53 272
330 [Python] \u3000을 공백으로 치환하기 이니스프리 이니스프리 23.10.29.14:51 274
329 [특가] 오늘 하루, TRON G41마우스 19,800원 특가 1 image 하루살이 title: 황금 서버 (30일)하루살이 17.02.27.13:00 275
328 컴퓨터로 가운뎃점을 쉽게 입력해보자 6 image 슬기 슬기 19.04.19.14:18 276
327 [Python Requests] multiple cookies를 다루기 - "There are multiple cookies with name python" 에러 처리 이니스프리 이니스프리 23.08.22.01:40 279
326 (펌) 앱코, 감성초월 레트로 키보드 K850 & K830 마지막 하루!! 1 image 하루살이 title: 황금 서버 (30일)하루살이 17.02.28.00:41 282
325 [할인정보] 트렌드마이크로 맥시멈 시큐리티 80% 할인! image 이니스프리 이니스프리 17.01.31.18:38 282
324 [할인정보] 더페이스샵 1월 멤버십데이 (오늘부터!) 1 image 이니스프리 이니스프리 17.01.02.10:19 283
323 [할인정보] Bullguard 백신 - 발렌타인데이 70% 할인 이벤트! 3 image 이니스프리 이니스프리 17.02.09.22:42 284
322 [Python] clint를 이용한 requests에서의 다운로드 프로그레스바 이니스프리 이니스프리 20.05.29.14:53 289
321 JavaScript와 Canvas로 이미지의 배경값을 자동으로 산출하기 Seia Seia 20.09.12.06:37 290
320 멘션 설정을 해주세요. 1 image 에듀 title: 맛스타의 자물쇠에듀 16.12.01.20:47 291
319 [Python] URL에서 파일을 다운받지 않고 파일용량를 알아내는 방법 3 이니스프리 이니스프리 20.05.13.21:01 291
318 하루에 포인트를 많이 쌓는 법 3 image title: 은메달도다 17.01.12.16:02 293
317 [건강/의학] 냄새 없애고 세균 죽이는 양치법. 1 image death death 17.01.25.21:18 296
316 [할인정보] Emsisoft 안티멀웨어 할인! 이니스프리 이니스프리 17.02.23.23:13 299
315 [Requests] r.text vs r.content 차이 이니스프리 이니스프리 19.12.27.22:40 299
314 기억력 증진을 위한 생활습관 12가지 image 오후두시스토리 오후두시스토.. 17.04.06.11:12 299
313 [정규식] 문자열에 괄호 넣기 이니스프리 이니스프리 20.07.01.18:37 301