• 목록
  • 아래로
  • 위로

안녕하세요?


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


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. (2%) 4154510/115200000EXP

Make StudyForUs Great Again!

 

CSVpuymXAAAVVpd.jpg

댓글 0

권한이 없습니다.
번호 제목 글쓴이 날짜 조회 수
공지 시스템 점검 작업 완료 안내 10 마스터 마스터 24.09.05.16:25 2060
공지 [중요] 호스팅 만료와 관련하여 일부 수칙이 변경됩니다. 4 마스터 마스터 23.01.14.02:23 8852
260 [파이썬] .replace() 카운트하는 방법 이니스프리 이니스프리 19.12.24.11:25 694
259 [파이썬] 길어진 로그 파일을 100줄로 줄이는 스크립트 이니스프리 이니스프리 19.12.25.11:49 196
258 [파이썬] 폴더 및 하위 폴더 내의 파일에서 문자열을 일괄적으로 replace하는 스크립트 이니스프리 이니스프리 19.12.25.13:01 1311
257 최근 KT 해외망 간단 리뷰 이니스프리 이니스프리 19.12.25.23:21 201
256 이베이에서 저렴하게 올라오는 보안 프로그램에 관하여 이니스프리 이니스프리 19.12.26.12:12 264
255 [Selenium] alert 창을 닫는 방법 및 alert 창이 뜨는 것을 차단하는 방법 1 이니스프리 이니스프리 19.12.26.23:01 4689
254 [Requests] r.text vs r.content 차이 이니스프리 이니스프리 19.12.27.22:40 367
253 [파이썬] .isalnum() - 정규표현식을 사용하지 않고 문자열 내 특수문자 사용 여부 확인 이니스프리 이니스프리 19.12.27.22:43 4496
252 [파이썬] 여러 개의 공백을 하나로 줄이는 방법 이니스프리 이니스프리 19.12.28.00:12 1349
251 [파이썬] 엔터를 치지 않아도 키 입력 받기 (윈도우) 이니스프리 이니스프리 20.01.01.12:28 768
250 [파이썬] 어제 날짜(연월일) 구하기 이니스프리 이니스프리 20.01.01.12:42 1747
249 [펌] 신발 깔창 리뷰 이니스프리 이니스프리 20.01.01.17:26 487
248 레노버 랩탑에서 Fn 키 설정 및 Ctrl 키와의 상호전환에 대하여 이니스프리 이니스프리 20.01.02.22:22 1197
247 [Selenium] 다운로드받은 파일명 변경 이니스프리 이니스프리 20.01.03.12:47 2856
246 [나리야] 마지막 알파버전 금일 업로드 image 이니스프리 이니스프리 20.01.03.12:51 161
245 Vivaldi 브라우저 2.10 업데이트 이니스프리 이니스프리 20.01.06.23:54 152
244 [파이썬] OS에 따라서 경로를 달리하기 이니스프리 이니스프리 20.01.07.22:15 303
243 [오프라인 강좌] 오픈소스 협업을 위한 Git 트레이닝 image 이니스프리 이니스프리 20.01.08.00:13 149
242 [카고야] 공지 메일이 왔네요~ 이니스프리 이니스프리 20.01.08.13:27 147
241 [Flutter] 오프라인 강좌 이니스프리 이니스프리 20.01.09.00:12 286