복습

231228복습

glenlee 2023. 12. 30. 01:56

# 문자열 함수
-function,method

# split(): split strings

coffee_menu_str = "에스프레소,아메리카노,카페라테,카푸치노"
coffee_menu_str.split(',')

"에스프레소,아메리카노,카페라테,카푸치노".split(',')

"에스프레소 아메리카노 카페라테 카푸치노".split(' ')

"에스프레소.아메리카노.카페라테.카푸치노".split('.')

phone_number = '+82-10-2345-6789'

# +82만 추출하기
result = phone_number.split('-')
result = phone_number.split('10-2345-6789')
result

## strip() : 필요없는 문자열 삭제
- 앞뒤 공백 혹은 개행문자와 같이 불필요한 부분을 지우고 싶을 때 사용

tempText = ' Python '
tempText.strip()

tempText = 'aaaaaPythonaaaaaa'
tempText.strip('a')

tempText = 'aaaaaPythonaaaaaa'
tempText[5:11]

tempText = 'aaaaabbPythonbbaaaaaa'
tempText[7:13]

tempText = 'aaaaabbPythonbbaaaaaa'
result = tempText.strip('a')
result.strip('b')

tempText.strip('ab')

tempText = '\n Python \n\n'
print(tempText.rstrip('\n'))
print(tempText.lstrip('\n'))

## join(): 문자열 연결
- 더하기 연산자(+)로 두 문자열을 연결 가능

name1 = '철수'
name2 = '영미'
hello = '안녕'

print(name1 + hello)
print(name2 + hello)

address_list = ['서울시', '서초구', '반포대로', '201(반포동)']
a = '.'

a.join(address_list)


".".join(address_list)

## find() : 문자열 찾기
- 문자열의 위치 값을 반환

str_f = 'Python code'
print(str_f.find('o'))
print(str_f.find('c'))
print(str_f.find('x'))

## count() : 찾고자 하는 문자열의 횟수 반환
- 만약, 찾을 문자열이 없으면 0으로 반환

str_a = "더 높이 더 빨리 더 멀리"
print(str_a.startswith("더"))
print(str_a.startswith("몼또"))
print(str_a.endswith("멀리"))
print(str_a.endswith("토오쿠"))

## replace() : 문자열 바꾸기
- 지정한 문자열을 찾아서 바꾸는 메서드

str_a = "더 높이 더 빨리 더 멀리"
str_a.replace(('더'),('존나'))

str_a = "더 높이 더 빨리 더 멀리"
str_a1 = str_a.replace(('더'),(''))
str_a2 = str_a1.replace(('높이'),(''))
str_a3 = str_a2.replace(('빨리'),(''))
str_a4 = str_a3.replace(('멀리'),(''))

print(str_a)
print(str_a1)
print(str_a2)
print(str_a3)
print(str_a4)

## append()
- 리스트에서 항목 하나를 맨 마지막에 추가


## insert()
- 항목의 위치를 나타내는 인덱스 i에 data를 삽입.

myFriends = ['James', 'Robert', 'Lisa', 'Mary']
myFriends.append('Thomas')
result.insert(1,'evan')
result

ex_list = ["a", "b", "c", "d"] # -1 => given position, 3번째 인덱스값을 참조
ex_list.insert(-1, "e") # append("e")
print(ex_list)
print(["a", "b", "c", "d", "e"])

## extend()
- 리스트에서 항목 여러 개를 맨 마지막에 추가

myFriends = ['James', 'evan', 'Robert', 'Lisa', 'Mary', 'Thomas']

newFriends = ['A', 'B', 'C']
# myFriends.append(newFriends)
myFriends.extend(newFriends)
myFriends

myFriends = ['James', 'evan', 'Robert', 'Lisa', 'Mary', 'Thomas','A', 'B', 'C']

newFriends = ['d', 'e', 'f', ]
myFriends.append(newFriends)#append 는 항목하나라서 def 한개로 취급
#myFriends.extend(newFriends)
myFriends



##**함수**

- 뺄셈 함수를 만들어보세요
  + 함수명 : mySubtract

def mySubtract(a, b): # 무조건 a, b가 입력이 되어야 함. 필수 조건
  c = a - b
  return c

a = 2
b = 1

result = mySubtract(a, b)
print(result)

def mySubtract(a, b=0): # b의 초깃값으로 0으로 설정 b = None
  c = a - b
  return c

x = 10
z = 100
result = mySubtract(x, z) # b가 0 => 100으로 변경
print(result)



def my_func():
  print("My first function")
  print("This is a function!")

my_func()

def mySum(a, b = 4):
  c = a + b
  print(f'함수 잘 작동 중? {c}')


a = 4
result = mySum(a)
print(result)

(f'함수 잘 작동 중? {c}')는 Python의 f-string을 사용한 문자열 포맷팅입니다.

f-string은 파이썬 3.6 버전부터 도입된 문자열 포맷팅 방법 중 하나로, 문자열 내에서 중괄호 {} 안에 변수나 표현식을 넣어 해당 값을 문자열로 대체하는 기능을 제공합니다.

여기서 '함수 잘 작동 중? {c}'는 문자열이고, 중괄호 {} 안에 있는 c는 변수입니다. f-string을 사용하여 {c}의 부분은 변수 c의 값으로 치환됩니다.

예를 들어, 코드에서 c = a + b로 초기화되고 있는데, 이때 f'함수 잘 작동 중? {c}'가 실행될 때 {c}는 해당 코드에서 c에 할당된 값을 문자열로 대체합니다.

따라서 실제로 프로그램이 실행될 때 '함수 잘 작동 중? ' 뒤에 c 값이 문자열로 변환되어 이어지게 됩니다. 만약 c의 값이 14라면 이 부분은 '함수 잘 작동 중? 14'와 같은 형태로 출력될 것입니다.

### 변수의 유효범위
- p121
- 지역 변수 & 전역 변수
- Local Variable & Global Variable

a = 5 # 전역 변수

def func1():
  a = 1 # 지역 변수
  print(f'func1 지역 변수 a = {a}')

func1()
print(f'전역 변수 a = {a}')

a = 50

def func1():
  a = 40
  print(f'여기서만 40 = {a}')

func1()
(f'여기서만 40 = {a}')

a = 5 # 전역 변수

def func1():
  a = 1 # 지역 변수
  print(f'func1 지역 변수 a = {a}')

def func2():
  a = 4 # 지역 변수
  print(f'func2 지역 변수 a = {a}')

def func3():
  print(f'func3 전역 변수 a = {a}')

def func4():
  global a # 함수 내 에서 전역 변수를 변경하기 위함
  a = 500
  print(f'func4 전역 변수 a = {a}')

func1()
func2()
func3()
func4() # 500이 이해 완료
print(f'전역 변수 a = {a}') # 여기도 500이 나오더라 이것이 포인트
func3()
func2()
func1()



### 람다 함수
- `def` 함수 같은 경우에는 복잡한 함수 로직을 만들 때 주로 사용
- 단순 기능을 수행 할 때, lambda 함수
  + 함수를 한줄로 처리

(lambda x : x **2)(3)

mySquare = lambda x : x ** 2
mySquare(5)

def myPower(x):
  y = x ** 2
  print(y)
#   return y

myPower(3)

## 클래스 선언과 객체 생성
- 함수의 확장
+함수 : 각 덧셈함수, 뺄셈함수 곰셈함수
+클래스 : 사칙연산 클래스 (예: 계산기)
+라이브러리 : 클래스들의 묶음


# 자전거의 속성 : data
# 자전거의 동작 : method (=function)

class Bycycle(): # 클래스 선언
  # 클래스 변수
  데이터1 = 바퀴의 크기
  데이터2 = 자전거의 색상

  # 클래스 메서드
  def 속도():
    pass

  def 방향():
    pass

  def 정지():
    pass

  def 비행():
    pass

객체명 = Bycycle(데이터1, 데이터2) # 입력한 형태로 새로운 객체가 막 생기는 것

# 상상
벤츠자전거 = Bycycle(데이터1, 데이터2) # 매장 옵션

# 문의
벤츠자전거 하늘로 비행하나요? ==> 얘는 기능 미 존재






계산기 만들기

result = 10

def s(num):
  global result

  result= result - num
  return result
print (s(5))
print (s(3))

- 계산기가 1대 더 필요한 상태

result1 = 0

def s1(num):
  global result1

  result1= result1 + num
  return result1

result2 = 0

def s2(num):
  global result2

  result2= result2 + num
  return result2

  
print(s1(3))
print(s1(5))
print(s2(3))
print(s2(8))

- 위 코드의 문제점 : 같은 기능(덧셈)을 수행하는 함수가 중복될 수 있음 / 코드의 가독성이 매우 급격하게 떨어지기 시작

- 점프 투 파이썬 클래스 예제



class Calculator:

  def __init__(self):
    self.result = 0 

class Calculator:

  def __init__(self):
    self.result = 0 

def d(self, num):
 
    self.result = self.result + num
    return self.result

print(cal1.d(5))
print(cal1.d(5))

class Calculator:

  def __init__(self):
    self.result = 0 


  def add(self, num):
    self.result = self.result + num
    return self.result
cal3 = Calculator() <-1회 계산 뒤에 지우고 셀실행시 cal 의 계산식이 중복으로 덧셈 위에서 값을 초기화 하기 떄문

print(cal3.add(100))

class Bicyle():

  # 변수 초기화
  def __init__(self, wheel_size, color):
    self.wheel_size = wheel_size
    self.color = color

  def stop(self):
    print('자전거({0}, {1}) : 정지'.format(self.wheel_size, self.color))
    

class Car:
    def __init__(self, speed, model):
        self.speed = speed
        self.model = model

    def stop(self):
         print('고속도로({0}, {1}) : 정지'.format(self.speed, self.model))

my_car = Car(100, 'gc')
ur_car = Car(80, 'vl')

my_car.stop()
ur_car.stop()

class Car:
    def stop(self):
        print('고속도로 : 정지')

# 객체 생성
my_car = Car()
ur_car = Car()

# 객체에 속성 추가
my_car.speed = 100
my_car.model = '3.8'

ur_car.speed = 80
ur_car.model = '2000'

# stop() 메서드 호출 및 속성 출력
my_car.stop()  # 출력: 고속도로 : 정지
print(f"my_car의 속성 - 속도: {my_car.speed}, 모델: {my_car.model}")

ur_car.stop()  # 출력: 고속도로 : 정지
print(f"ur_car의 속성 - 속도: {ur_car.speed}, 모델: {ur_car.model}")

 

'복습' 카테고리의 다른 글

loc 와 iloc의 차이  (1) 2024.01.05
240103복습  (0) 2024.01.03
231229 복습  (2) 2023.12.30
변수의 형태 chat gpt  (0) 2023.12.30
231227 학습내용  (0) 2023.12.28