여기 있어요 : Home Dive Into Python 3

“파이썬3로 뛰어들기”에서 바뀐점

여기가 들어왔던 곳이 맞나?
— 핑크 플로이드, The Wall

 

다시 말해 준비 레벨

당신은 파이썬 프로그래머인가요? 파이썬으로 뛰어들기를 읽었나요? 책으로? (그렇다면, 고마워요!) 파이썬3로 뛰어들 준비가 됐다고요? 그렇다면, 이 장을 읽으세요. (이 중 하나에도 해당하지 않는다면, 다음 장부터 읽어나가세요.)

파이썬3는 2to3이라는 스크립트와 함께 왔습니다. 이 스크립트를 배우고, 사랑하고, 쓰세요. 2to3을 통해 파이썬3로 옮기는 법 에는 2to3이라는 툴이 자동적으로 바꿔주는 모든 것에 대한 설명이 있습니다. 문법의 변경이 대부분이기 때문에, 이를 통해 파이썬3에서 바뀐 문법을 상당부분 배우게 됩니다. (print구문이 함수가 되었기 때문에, `x`가 더이상 사용될수 없는 것 등등)

사례 연구: 파이썬3로 chardet 옮기기 문서는 파이썬2의 유용한 라이브러리를 파이썬3로 옮기려는 제 노력의 결과입니다. (아, 자랑은 아니지만 매우 성공적이었죠!) 이런 경험이 당신을 도와줄 수 있을겁니다, 아닐수도 있고요. 배우는 과정이 쉽지는 않을 겁니다. 우선 라이브러리에 대한 이해가 필요합니다. 그래야만 이것이 왜 망가졌는지, 제가 이걸 어떻게 고쳤는지 이해가 될겁니다. 많은 파손들이 문자열 때문에 일어납니다.

문자열이라, 휴, 어디서부터 시작해야 할지. 파이썬 2에서는 문자열과 유니코드 문자열이 있었죠. 파이썬3는 바이트와 문자열이 있습니다. 이제 모든 문자열은 유니코드로 작성됩니다. 바이트 열을 다루려면 새롭게 등장한 bytes 타입을 사용하세요. 파이썬3에서는 문자열이 바이트로 자연스레 변하지 않기 때문에, 언제 무엇을 써야하는지 모르는 상태에서 작업을 한다면, 그 코드는 분명히 문제가 생기게 됩니다. 자세한 이야기는 문자열 장에서 나누기로 하죠.

바이트 대 문자열의 싸움은 이 책을 읽어나가면서 계속해서 등장하게 됩니다.

유니코드에 대해 별 관심이 없다해도 (결국 관심이 생기게 되겠지만), 파이썬2와는 완전히 다른 파이썬3에서의 문자열 형식화에 대해서는 읽어보고 싶을겁니다.

반복자는 Python 3 어디에나 있습니다, 그리고 저는 그것들을 파이썬으로 뛰어들기를 썼던 5년전보다 훨씬 잘 이해하고 있습니다. 당신도 이해가 필요할겁니다. 파이썬2에서 리스트를 뱉어내던 많은 함수들이, 파이썬3에서는 반복자를 뱉기 때문이죠. 적어도, 반복자 장의 뒷쪽 절반쯤은 읽어보세요. 고급 반복자 장의 뒷부분도요.

많은 요청들 때문에 , 특별한 메소드 이름을 부록으로 첨부했습니다, 파이썬 공식문서 중 “데이터 모델” 장과 비슷하지만 좀더 snark(?)하죠.

처음 파이썬으로 뛰어들기를 썼을 때는 괜찮은 XML라이브러리가 없었습니다. 그러다 Fredrik 과 Lundh가 ElementTree라는 뛰어난 라이브러리를 만들었죠. 파이썬의 여러 고수들이 현명하게도 표준 라이브러리에 ElementTree를 통합시켰습니다, 이를 기본으로 새로운 XML 장을 구성하였습니다. 예전 방식의 XML 해석이 여전히 가능하지만, 쓰지 마세요. 구립니다.

또한 새로워진 것으로는 — 언어자체의 변화가 아니라 커뮤니티의 변화로 — 파이썬 패키지 목차 (PyPI) 처럼 급할 때 가져다 쓸 소스 저장소(?)가 생겼습니다. 파이썬은 만든 코드를 포장하고 배포하는 표준 형식을 유틸리티로 만들었습니다. 자세한 정보는 파이썬 라이브러리 패키지를 읽어보세요.

© 2001–11 Mark Pilgrim