너무 오래 전이라 책을 다시 보면서 정리 ====== 문법요소 ====== * pass : 아무것도 하지 않는다 * 함수 시작 부분에 " 나 """ 로 설명을 적어두면 __doc__ 속성에 저장되어 도움말로 사용된다. ===== import ===== import 모듈 from 모듈 import 어트리뷰트 from 모듈 import * import 모듈 as 별칭 ===== 자료형 ===== * 참조는 기본 * 주소확인 : id(어떤 변수) * 리스트, 세트, 튜플, 사전 * 리스트 완전 복사 : copy.deepcopy(XX) * '**' 연산자 : pow() ==== 문자(열) ==== * (')나 (") 중 아무거나 사용. * 시작과 끝이 같은 기호로 끝나야 한다. 'abcde' # ok 'abcde" # error 아래 부분은 v2.x 에 해당되는 내용. v3는 기본 유니코드라서 u를 붙일 필요가 없어졌다. * 한글과 같은 문자를 표현하려면 유니코드를 사용 * 상수형 문자열이라면 u'...' 기호 u를 붙여서 선언 가능하고 str1 = u'한글또는 외국어' * 변환 해야 한다면, '가'.encode('utf-8') # 바로 인코딩해서 넘기는 방법 * '+' 로 문자열 결합 * rjust(NUM) : 오른쪽 정렬 * ljust / center * zfill() : 0으로 채우기 ==== 튜플 ==== * 읽는 용도의 데이터 설정 * 괄호 안에 항목을 넣는다. gameDir = ('skyrim', 'NinjaOfTheMark') gameDir[0]을 치면, 'skyrim'이 출력된다. ==== 리스트 ==== * ([,]) 기호 내부에 항목을 선언한다. * 배열 요소를 탐색하는 여러 방법이 있는데, 나중에 정리하자. gameDir = ['skyrim', 'NinjaOfTheMark'] gameDir[0] # 0번째 항목 리턴 gameDir.count() # 개수 gameDir.pop() # 데이터를 얻은 다음 삭제 ===== 함수 ===== 함수 선언 방법 def <함수이름>( 인자1, 인자2, ... ): <구문> return <리턴값> ===== 스코핑룰 ===== 전역변수를 사용하고 싶다면, >>> g = 1 >>> def test_scope(a): global g # g는 전역변수를 가리킨다 g = 2 return g+a ===== 키워드인자 ===== 파라미터의(인자) 이름으로 값을 지정해서 사용하는 방법. 파라미터 순서를 지키지 않아도 된다. >>> def connURI(server, port): return "abc" >>> connURI(port="8080", server="test.com") ===== 가변 ===== 인자 이름 앞에 '*'를 붙이면 가변으로 (튜플로서) 인식된다. >>> def test(*args): print(type(args)) 정의되지 않은 인자 처리 : 인자이름 앞에 '**' 타입 미정의 가변 인자를 사용할 수 있다. 마지막에 와야 한다. ===== 람다 ===== lamda 인자 : <구문> ===== 이터레이터 ===== 자료형 데이터에 순환하는 이터레이트를 쓸 수 있다 s = 'abc' it = iter(s) # 이터레이터를 얻는다 next(it) # 다음 요소로 이동 it.__next__() # 다음 요소로 이동 * **yield** : 함수를 끝내지 않고 호출한 곳에서 리턴 값을 전달한다. 함수는 계속 실행. 오오 ===== 비교문 ===== num >= 70 && num < 80 --> 70 <= num < 80 형식으로 사용할 수 있다. if 70 <= num < 80: ... ^ and, & \\ or, | ^ | &| 는 if 문 전체를 비교하고 종료 \\ and 와 or를 사용하면 조건에 맞으면 비교를 끝내고 다음문장으로 이동 | ^ for ^ | range()함수로 실행 횟수 방식으로 실행 가능 \\ for i in range(10): print(i) # 0 .. 9 까지 11번 반복해서 i를 출력 | ===== 클래스 ===== * 클래스 함수의 첫 인자는 self (클래스 자신) * 클래스 변수 선언시 값 인력 가능, 이건 클래스 변수가 된다. 인스턴스에서 값을 입력하면 다른 변수가 생긴다. * 클래스에 대해서도 동적으로 멤버 변수 추가 가능. 추가 후 모든 인스턴스에서 사용 가능. * 인스턴스객체에 동적으로 멤버변수 추가/삭제 가능 * 인스턴스에서 클래스에 접근하기 __class__ 키워드인자 * isinstance(INST, CLASS) : 상속 관계 확인 * 생성자 __init__(self, value), 소멸자 __del__(self) * 인스턴스 삭제 : del . 레퍼런스가 0이되면 __del__()호출된다. * 정적메소드와 클래스 메소드 두종류. 클래스 메소드는 self를 받을 첫번째 인자가 필요하다. * 함수 선언 후, staticmethod(), classmethod()로 재선언하여 정적/클래스 함수를 정의한다. ==== 연산자중복정의 ==== 연산자 중복 정의를 위한 미리 정의된 함수가 있다. '-' 면 __sub__ 라든지. ==== 클래스 상속 ==== class Parent: pass class Child(Parent): pass ==== 메서드 재정의 ==== 부모 메서드와 자식쪽의 메서드의 이름만 같으면 재정의(오버라이딩)된다. super()로 부모 클래스 메소드 호출 ===== 예외처리 ===== try: <구문> except <예외종류>: else: 예외가 없는 경우 finally: 예외 상관 없이 try 블록 실행 후 raise <예외> : 예외 발생 시킨다. ===== assert ===== assert <조건식>, <관련데이터> ===== 입출력 ===== ==== 출력 ==== print(<문자열>) import sys sys.stdout.write('test') * rjust(NUM) : 오른쪽 정렬 * ljust / center * zfill() : 0으로 채우기 ==== 포맷팅 ==== "스트링 {0}".format(<파라미터>...) **{0}** 대신 사전식 방법 사용 가능 >>> print("{item} is color".format(item="apple")) >>> dic = {"item":"apple", "color":"red"} print("{0[item]} is {0[color]}".format(dic)) 지역변수를 사전 형식으로 사용 가능. locals() 사용 >>> item = "apple" >>> color = "red" >>> print("{0[item]} is {0[color]}".format(locals())) 사전자료형을 쓰는 경우, 앞에 **를 붙이면 값으로 판단하고 사용된다. 이러면 파라미터에 0을 붙이지 않아도 된다. 변수의 인덱스를 사용할 수 있다 numz = [5,4,3,2,1] print("{numz}".format(**vars())) print("{numz[0]}".format(**vars())) ==== 입력 ==== a = input('press key') ===== pickle ===== 객체류의 데이터를 파일로 저장 ===== ctypes ===== C나 dll 에서 함수 불러서 사용하기 ===== decimal ===== 정확한 정수와 부동소수점 표현을 위한 클래스 =====random===== random.random(), random.randomrange(N) random.sample(N,N) : 노 중복 ====== 함수들 ====== = type(어떤 변수) : 타입체크 = id(어떤 변수) : 주소확인 = globals() : 내장함수 확인 = __builtins__ : 내장함수의 리스트. dir(__builtins__) = help(xx) : 도움말을 불러온다 = filter(METHOD, DATA) : 조건에 맞게 필터링된 이터레이터 객체 리턴 = zip() : 두개의 리스트를 묶어 튜플로 만든다 = zip(*인자) : 튜플인자에 *를 붙여 사용하면 리스트로 다시 분리 = map() : 시퀀스형 객체를 순회하면서 모든 값에 대해 뭔가 처리가 필요할때 (값 갱신) = join() : 문자열 내장함수, 자료형 객체의 모든 값을 합하는데.. 빠르다는데.. 어디다가?? ===== os 관련 주요 모듈 ===== = os.getcwd() : 현재 디렉토리 경로 얻기 = os.chdir( path ) : 디렉토리, 현재 위치를 변경 = os.access( path, mode ) : path에 대해서 mode에 해당하는 작업이 가능한지 확인 = : F_OK 파일 존재 여부 = : R_OK, W_OK : 읽기 쓰기가 가능한지 확인 = : X_OK : 실행 가능한가 확인 = os.sys tem( command ) : command 를 실행하며 성공한 경우 0을 리턴. ===== 그외 ===== 파일 복사,이동 import shutil shutil.copy( 원본파일, 대상 디렉토리 ) shutil.move( 원본파일, 대상 디렉토리 ) ====== 추가모듈 ====== * 스펠체크 : flake8