language/Python
python 2 vs python 3 주요 차이점
스파이디웹
2021. 8. 19. 14:53
728x90
프로젝트를 하면서 python2 version과 python3 version의 차이 때문에 생긴 에러가 있었는데, 그에 따라 python version 별 차이점을 간단하게 정리해보려고 합니다.
1. 프로젝트에서 발생한 에러
spark 프로젝트를 하면서 L 즉 LongType의 데이터를 다루게 되었습니다. 해당 코드도 그에 맞게 작성 했는데,
python 2 version로 script를 돌릴 때는 문제없이 돌 던 것이 default로 설정 되어있던 python 3 version에서는 에러가 발생했습니다.
log를 살펴보니,,, LongType에 관한 에러라고 나왔고.
python 2 와 3의 차이점을 살펴 보았습니다.
PYTHON 2 | PYTHON 3 | |
PRINT가 함수가 아니라 ()없이 ""만으로도 사용 할 수 있었다. | PRINT가 함수가 되면서 ()는 필수가 되었다. | |
LONG*(프로젝트issue와 관련된 변경사항) | LongType, IntType이 따로 있었다. | LongType은 사라지고 IntType로 통합되었다. |
int/int | int/int 2/3은 0(int)으로 나온다. | int/int 2/3은 0.66666 (float)으로 나온다. |
String, unicode | string type unicode type 따로 있었다. | String type으로 통일, bytes 타입이 생겼다. |
이외에도 다양한 변경점이 있지만, 주요한 변경점은 위와 같다고 볼 수 있습니다.
2.프로젝트 issue 해결
python3에서는 LONG type이 사라지면서 Long type을 인식하지 못하는 에러를 뿜어내고 있었습니다.
우선 급한대로 python2 와 3을 호환하는 코드를 작성하진 않았고, (기존의 HQL -> pyspark 으로 변환하는 작업이라)
기존 python2 interpreter를 사용하여 에러를 회피하였습니다.
728x90