goodthings4me.tistory.com
■ 파이썬의 클래스 상속(inheritance)
# 부모클래스가 갖는 모든 메서드가 자식클래스에도 담긴다.
# 자식클래스에는 별도의 메서드를 추가할 수 있다.
class Father:
def run(self):
print('so fast..!')
class Son(Father):
def jump(self):
print('so high..!')
def main():
s = Son()
s.run() # so fast..! / 상속된 메서드
s.jump() # so high..! / 추가된 메서드
main()
■ 메서드 오버라이딩
# 상속 관계에서 부모클래스의 메서드와 동일한 이름의 메서드를 자식클래스가 정의하는 것
# 이 경우, 부모메서드는 보이지 않는 상태가 된다.(호출 불가 상태)
class Father:
def run(self):
print('so fast..!')
class Son2(Father):
def run(self): # Father 클래스의 run 메서드 가림(오버라이딩)
print("so fast, son's style")
def main():
s2 = Son2()
s2.run() # so fast, son's style / Son2의 run 메서드 호출
main()
# Son2의 객체에는 Father의 run과 Son2의 run이 모두 존재한다.
# Father의 run이 가려졌을 뿐, 가려진 run도 호출할 수 있다.
class Father:
def run(self):
print('so fast..!')
class Son3(Father):
def run(self):
print("so fast, son's style")
def run2(self):
super().run() # 부모클래스의 run() 호출 (가려진 run)
def main():
s3 = Son3()
s3.run() # so fast, son's style
s3.run2() # so fast..!
main()
■ __init__ 메서드 오버라이딩
class Car:
def __init__(self, carnumber, fuel):
self.carnumber = carnumber
self.fuel = fuel
def drive(self):
self.fuel -= 10
def add_fuel(self, f):
self.fuel += f
def show_info(self):
print('car type :', self.carnumber)
print('fuel :', self.fuel)
class Truck(Car):
def __init__(self, carnumber, fuel, c): # 부모클래스 변수 초기화값도 같이 전달받음
super().__init__(carnumber, fuel) # 부모 __init__ 호출 / 변수 초기화
self.cargo = c # 자식 변수 초기화
def add_cargo(self, c):
self.cargo += c
def show_info(self):
super().show_info() #부모클래스 show_info 메서드 호출
print('cargo :', self.cargo)
def main():
t = Truck('43럭5959', 0, 0)
t.add_fuel(100)
t.add_cargo(50)
t.drive()
t.show_info()
main()
[실행 결과]
car type : 43럭5959
fuel : 90
cargo : 50
[참고자료] 윤성우의 열혈파이썬 중급편
블로그 인기글
[엑셀] 근무연수 및 근무 개월수 계산하는 함수
직장을 다니다 보면 몇 년 몇 개월 또는 전체 며칠을 다니고 있는지 궁금할 때가 있다. 아니면, 총무나 인사 일을 할 때 직원들의 근속연수 또는 근속개월수 등을 계산하고 싶을 때도 있다. 이런 경우 엑셀 함수를 활용하면 어떨까!! 근무연수 및 근무 개월수 계산 함수 알아보기 엑셀에서 근무연수 또는 근무 개월수 계산하는 것은 datedif() 함수를 사용하면 간단하게 해결할 수 있다. 아래 이미지를 보면서 설명하면, 셀 E1에 기준일자를 입력하고, 근무연수를 구할 때는 =datedif(B3,$E$1,"Y")&"년" 을 입력한다. 근무개월수는 =datedif(B3,$E$1,"M")&"개월" 처럼 입력한다. 일수까지 파악할 때문 별로 없지만, 심심풀이로 구해보고 싶을 때 =datedif(B3,$E$1,"D")..
goodthings4me.tistory.com
폐업 신고 절차와 부가가치세 신고하는 방법
폐업 신고 시 세무서 안 가고 온라인으로 신고하는 방법인 '국세청 홈택스를 이용하여 폐업 신고하는 절차와 폐업 후 해야 하는 부가가치세 신고, 인건비 저리, 종합소득세 신고 등에 대해 포스팅합니다. 폐업 신고 시 홈택스 이용하는 방법과 부가가치세 등 신고 절차 여러가지 사유로 폐업을 해야 할 때, 예전에는 세무서를 방문해야 했지만 국세청 홈택스가 생긴 이후에는 사업자 등록이나 폐업 등을 인터넷으로 할 수가 있게 되었습니다. 특히, 코로나 시국인 요즘은 더더욱 온라인 신청 업무가 더 활성화되었죠. 폐업을 한다는 것 자체가 우울한 일인데, 발품을 파는 것보다는 커피 한잔 하면서 인터넷으로 간단하게 처리하는 게 좋을 듯하여 그 절차를 올려봅니다. 폐업은 폐업 신고와 함께 폐업 후 절차까지 모두 마쳐야 불이익이..
goodthings4me.tistory.com
엑셀 시트 분리 저장 - 엑셀 파일의 시트를 분리하여 저장하기
엑셀을 사용하다 보면 엑셀 시트를 분리해서 저장해야 할 때가 있다. 최근에도 이런 경우가 발생하여 구글링 후 엑셀 시트 분리 업무를 수행하고 내친김에 다른 사람들도 사용할 수 있도록 파이썬 tkinter로 프로그램으로 만들어 보았다. Excel Sheets 분리 저장하는 프로그램(with 파이썬 Tkinter) ※ 프로그램 다운로드(네이버 MYBOX에서 공유) : ExcelSeparateSheets.zip ▶ 프래그램을 실행하면 다음과 같이 초기 화면이 보인다. 찾아보기 : 엑셀 파일이 있는 폴더를 선택한다. (프로그램이 있는 최상위 디렉터리가 열린다) 실행하기 : 프로그램 실행 버튼 상태 변경 순서 : 실행전 → 실행 중 → Sheet "OOO" 분리 저장 중 → 실행 완료 실행 결과 확인 : 엑셀 파..
goodthings4me.tistory.com
'코딩 연습 > 코딩배우기' 카테고리의 다른 글
[python] 파이썬 __init__, __str__, __iter__, __next__ 등의 메서드 (0) | 2020.09.12 |
---|---|
[python] 파이썬 파일 쓰기, 읽기 - open(), read(), readline(), readlines() (0) | 2020.09.11 |
[python] 파이썬 클래스와 객체의 본질, 그리고 독특한 특성 (0) | 2020.09.09 |
[python] 파이썬 sort(), sorted() 알아보기 (0) | 2020.09.08 |
[python] 파이썬 enumerate와 문자열 비교 (0) | 2020.09.08 |
댓글