파이썬에서 정렬 기능을 가진 함수는 크게 sorted(), .sort()를 사용한다.

 

a = [(1, 2), (3, -2), (-4, 9), (5, 7)]


# 아무 인자 없이 sorted()만 사용 했을 경우, 내림차순으로 기본 정렬된다.
b = sorted(a)
print(b) # [(-4, 9), (1, 2), (3, -2), (5, 7)]


# key 인자에 함수를 넘겨주면 해당 함수의 반환값을 비교하여 순서대로 정렬한다.
# 익명함수 lambda 사용한 sorted함수 
c = sorted(a, key=lambda x: x[0])
d = sorted(a, key=lambda x: x[1])
print(c) # [(-4, 9), (1, 2), (3, -2), (5, 7)]
print(d) # [(3, -2), (1, 2), (5, 7), (-4, 9)]


# 첫 번째 인자를 기준으로 오름차순으로 먼저 정렬하고,
# 그 안에서 다음 두 번째 인자를 기준으로 내림차순 또는 오름차순으로 정렬하게 하려면
e = [(0, 2), (0, -1), (3, 5), (7, 2), (1, 1), (1, 0)]

f = sorted(e, key=lambda x: (x[0], x[1])) #오름차순
g = sorted(e, key=lambda x: (x[0], -x[1])) #내림차순
print(f) #[(0, -1), (0, 2), (1, 0), (1, 1), (3, 5), (7, 2)]
print(g) #[(0, 2), (0, -1), (1, 1), (1, 0), (3, 5), (7, 2)]

 

- sorted()의 key 인자로, 내가 기준으로 지정하려는 비교 함수를 넣어준다.

 

- 비교 함수는 익명함수(lambda)도 가능하고, 별도로 함수를 만들어 사용해도 된다.

 

- 비교할 아이템의 요소가 여러개일 경우, 튜플로 순서를 묶어 사용한다. ( - 를 붙이면, 반대로 정렬을 한다.)

반응형

Python 리스트(List)  공부 

 

리스트 자료형

데이터들의 목록으로 많은 데이터들을 다룰 때 편리하다.

기본적인 사용 방법은 '리스트명(변수) = [요소 1, 요소 2, 요소 3,... , 요소 n]' 같이 사용한다.

리스트는 [ ](대괄호)를 이용한다.

 

 

1. 리스트 만들기

 

a = [] # 요소가 없는 빈 리스트 
b = [1, 2, 3] # 요소가 정수 
c = ["A", "B", "C"] # 문자열 
d = ["A", "B", 1, 2] # 혼합 
e = [1, "A", [2, "B"]] # 혼합 + 리스트 안에 또 다른 리스트 

print(a) 
print(b) 
print(c) 
print(d) 
print(e)
#출력

[] 
[1, 2, 3] 
['A', 'B', 'C'] 
['A', 'B', 1, 2] 
[1, 'A', [2, 'B']]




 

2. 인덱싱, 슬라이싱

 

인덱싱과 슬라이싱은 여러 요소들이 하나로 합쳐진 형태인 경우에 모두 사용하다.

따라서, 문자열이란 하나하나 문자들이 순서대로 나열된 형태이고, 리스트란 하나하나 요소들이 순서대로 저장되는 형태이다.

my_list = ["이몽룡", "홍길동", "임꺽정"]

print(my_list) 
print(my_list[0] + "님") 
# 리스트의 첫 번째 요소가 '문자열'이기 때문에 
# 인덱싱해서 가져온 값은 그대로 '문자열'이다.
#출력

['이몽룡', '홍길동', '임꺽정'] 
이몽룡님

 

1) 인덱싱 사용 비교(문자열 vs 리스트)

문자열 : 모든 요소가 문자이기 때문에 인덱싱하면 '문자'

리스트 : 각 요소의 형태에 따라 인덱싱 결과가 다르다.

 

2) 이중 리스트 인덱싱 (리스트 안에 또 다른 리스트 요소를 가지는 경우)

my_list = ["김철수", "홍길동",["임꺽정", "이몽룡"]] 

print(my_list[2]) # 리스트 
print(my_list[2][1]) # my_list의 3번째 요소인 리스트에서 2번째 요소 '이몽룡' 인덱싱 
print(my_list[2][1][1]) 
# 인덱스 범위 초과, 음수 사용 이런 인덱싱 개념은 동일
#출력

['임꺽정', '이몽룡'] 
이몽룡 
몽

 

a = [2, "2"] 
print(a[0] * 2) 
print(a[1] * 2)
#출력

4 
22 #문자 '2'가 2개 나열된 형태

 

 

3) 슬라이싱

리스트의 요소가 하나 밖에 없어도 슬라이싱의 결과는 무조건 '리스트'이다.

 

a = [2, "2"] 

print(a[0:2]) 
print(a[0:1])
#결과

[2, '2'] 
[2]

 

4) 리스트 연산

a = [1, 2, 3] 
b = [4, 5, 6] 
print("리스트 덧셈 :", a + b) # 연결 
print("리스트 곱셈 :", a * 2) # 반복 

c = a + b 
print(c) #새로운 리스트가 만들어진다.
#결과

리스트 덧셈 : [1, 2, 3, 4, 5, 6] 
리스트 곱셈 : [1, 2, 3, 1, 2, 3] 
[1, 2, 3, 4, 5, 6]

 

 

 

5) 리스트 수정(변경, 삭제)

 

a = [1, 2, 3, 4, 5, 6] 
a[2] = -1 
print("변경 후 :", a)

#결과

변경 후 : [1, 2, -1, 4, 5, 6]

 

# 연속된 범위의 값을 수정 
a[0:2] = [0] 
print("변경 후 :", a) 
a[0:2] = [6, 7, 8] # 하나씩 들어간다. 
print("변경 후 :", a)

만약, a[0:2] = 0 --> 오류, 슬라이싱의 결과는 '리스트' 이기 때문이다.

#결과

변경 후 : [0, -1, 4, 5, 6] 
변경 후 : [6, 7, 8, 4, 5, 6]

리스트 요소 삭제는 del(a[0]), del(a[0:2]) 같이 del()함수를 이용해 요소를 삭제한다.

 

 

6) 리스트 관련 함수

 

append(value) : 리스트 가장 뒤에 value(요소)를 추가

 

 

문자열은 수정이 불가능하기 때문에 새로운 문자열을 만들어내는 함수이다. 즉, 아래 예제에서 a라는 리스트 자체가 변경된다. append함수는 하나의 요소만 추가할 수 있다.

 

a = [1, 2, 3]

a.append(4)

print("변경 후 :", a)
#결과

[1, 2, 3, 4]

 

 

② sort() : 리스트 정렬하기 (숫자, 알파벳 등)

a = [2, 3, 1, 4] 
print("변경 후 :", a)


a.sort() # 기본 오름차순 
print("변경 후 :", a)


a.sort(reverse = True) # 내림차순 
print("변경 후 :", a)
#결과

변경 후 : [2, 3, 1, 4] 
변경 후 : [1, 2, 3, 4] 
변경 후 : [4, 3, 2, 1]

 

③ reverse() : 리스트 뒤집기 (정렬x, 현재 요소를 그대로 뒤집는다.)

a = [1, 3, 2, 4] 
a.reverse() 
print("변경 후 :", a)
#결과

변경 후 : [4, 2, 3, 1]

 

④ index(value) : 리스트에서 value를 찾고, 그 위치를 반환

만약 찾는 값이 없다면, 오류가 발생한다.

 

a = [1, 2, 3] 
print("a에서 2의 위치 :", a.index(2))
#결과

a에서 2의 위치 : 1

 

⑤ insert(index, value) : 지정한 위치(index)에 값(value) 삽입

append함수와 차이는 append함수는 맨 뒤에 값을 추가하고, insert함수는 지정한 위치에 값을 추가한다.

 

⑥ remove(value) : 리스트에서 '처음' 찾은 값(value) 제거

만약 없는 값을 제거하려고 하면 오류가 발생한다.

 

a = [1, 2, 3, 1] 
a.remove(1) 
print("변경 후 :", a)

#결과

변경 후 : [2, 3, 1]

 

또 다른 값을 제거하는 함수로 del() 이 있다. remove함수와 차이는 다음과 같다.

del(a[0]) --> 첫 번째 요소를 제거(0은 순서)
a.remove(0) --> 정수 0을 찾아서 제거 (0은 값)

 

⑦ count(value) : 리스트에 존재하는 value의 개수를 반환

a = [1, 2, 3, 1, 1, 1, 2, 3, 2, 1, 3, 1, 3, 2] 
print("a에서 2의 개수 :", a.count(2)) 
print()

#결과

a에서 2의 개수 : 4

 

⑧ pop(index) : 리스트에서 (index) 번째 값을 '뽑아낸다'

뽑아낸 값을 '반환'해주고 해당된 인덱스의 값은 제거된다.

 

a = [1, 2, 3, 1] 
print(a.pop(1)) 
print("변경 후 :", a) 
print(a.pop()) # index를 사용하지 않으면 기본 '맨 뒤' 값 선택
print("변경 후 :", a)
#결과

2 
변경 후 : [1, 3, 1] 
1 
변경 후 : [1, 3] 

 

⑨ len() : 요소의 개수를 구하는 함수

a = [1, 2, 3, 4] 
b = "1234" 
c = 1234 

print(len(a)) 
print(len(b))

print(len(c)) # 오류

 

#결과

4 
4
오류

 

위의 예에서 a, b는 각각 리스트, 문자열로 어떤 단일 값이 여러 개 존재하는 경우이다. 하지만 c는 단 하나의 숫자이기 때문에 개수를 구할 수 없다. len함수는 값이 여러개 존재하는 자료형만 사용할 수 있다.

 

⑩ copy() : 모든 값들을 '복제'하여 새로운 리스트 생성

a = [1, 2, 3, 4] 
b = a.copy() 
c = a 

print("기존 a :", a) 
print("복제 b :", b) 
print("대입 c :", c)
#결과

기존 a : [1, 2, 3, 4] 
복제 b : [1, 2, 3, 4] 
대입 c : [1, 2, 3, 4]

 

⑪ clear() : 리스트의 모든 요소 제거

a.clear() 
print(a) # 요소만 제거, 빈 리스트가 된다.

#결과

[]

 

⑫ join() : 리스트의 요소들이 모두 '문자열'인 경우에 '하나의 문자열'로 만들 수 있다.

my_list = ["대", "한", "민", "국"] 
print("".join(my_list))

#결과

대한민국
반응형

1.

upper() : 문자열의 영문을 모두 대문자로 변환하여 새로운 문자열을 만든다.
lower() : 문자열의 영문을 모두 소문자로 변환하여 새로운 문자열을 만든다. 

str1 = "I'm a Boy" 
print(str1.upper()) 
print(str1) # 문자열은 수정 불가능해서 원본 그대로
#결과

I'M A BOY 
I'm a Boy

 

2.

title() : 문자열에 존재하는 '영단어'의 첫 글자를 대문자로 변경

str2 = "python python python" 
print(str2.title()) 
print(str2)
#결과

Python Python Python 
python python python

 

3.

strip() : 문자열 좌우측에 존재하는 '공백'을 제거

str3 = "       공 백 제 거       " 
print(str3.strip()) 
# 공백이 아닌 문자를 만날때까지만 공백을 제거
#결과

공 백 제 거 

 

4.

join() : 특정 문자열을 대상 문자열에 삽입

 

# "A".join("BBB") --> "BABAB"

print(".".join("문자열 삽입함수 join()"))
#결과

문.자.열. .삽.입.함.수. .j.o.i.n.(.)

 

5.

count("A") : 문자열에서 "A"의 개수를 반환 (함수의 결과 값이 A의 개수)

 

str3 = "python python python" 
print("str3에서 p의 개수 :", str3.count("p")) 
print("str3에서 py의 개수 :", str3.count("py"))

# 결과 값이 '개수'이기 때문에 숫자 (정수) 
print("str3에서 x의 개수 :", str3.count("x"))
#결과

str3에서 p의 개수 : 3 
str3에서 py의 개수 : 3 
str3에서 x의 개수 : 0

 

6.

replace("A", "B") : 문자열에서 모든 "A"를 찾아서 "B"로 변경

 

str4 = "replace : python python python" 
print(str4.replace("py", "Py")) 
str3 = "       공 백 제 거       " 
print(str3.replace(" ", ""))
#결과

replace : Python Python Python 
공백제거

 

7. 

index("A") : 문자열에서 "A"를 찾고, 그 위치(index) 반환 (찾지 못하면 오류)

--> 찾은 단어의 첫 위치를 반환하고, index함수 안에 넣은 문자를 찾지 못하면 오류가 난다.

 

str5 = "문자열 위치 찾기 (index)" 
print("str5에서 '열'의 위치 :", str5.index('열')) # count처럼 정수 반환 
print("str5에서 '열'의 위치 :", str5.index("index"))
#결과

str5에서 '열'의 위치 : 2 
str5에서 '열'의 위치 : 11

 

print("문자열문자열".index("열")) # 처음 찾은 위치 
print("문자열문자열".rindex("열")) # reverse : 뒤집다 --> 뒤에서부터 찾음

print("문자열문자열문자열".index("열", 3)) # 3번 인덱스부터 찾기 시작
#결과

2 
5 
5 

 

8.

find("A") : index()와 같다. (단, 찾지 못하면 -1이 반환) , index()와 마찬가지로 rfind() 함수가 있다.

 

print("abcdefg".find("a")) 
print("abcdefg".find("z"))
#결과

0 
-1

 

9.

split("A") : 문자열을 기준 문자("A")로 나눈다.

split()에 기준문자를 따로 정해주지 않으면, 기본이 공백, 여백, 개행 등으로 나누어 준다. split함수 결과는 list자료형이다.

 

str6 = "문자열 나누기 (split)" 
print(str6.split())

print(str6.split("기"))
#결과

['문자열', '나누기', '(split)'] 
['문자열 나누', ' (split)']

 

10. 

eval(expression) : 문자열로 표현된 파이썬 식을 인수로 받아 결과값은 내주는 파이썬 내장함수로 문자열로 된 수식을 계산할때 유용하게 사용될 수 있다.

>>> eval('1+2')
3
>>> eval("'hi' + 'a'")
'hia'
>>> eval('divmod(4, 3)')
(1, 1)
반응형

 

 파이썬 문자열 - 연산, 인덱싱, 슬라이싱, 포매팅 공부

1. 문자열 만들기

문자열을 만드는 방법으로 4가지가 있다.

  • 1. 큰 따옴표 1개

  • 2. 작은 따옴표 1개

  • 3. 큰 따옴표 3개

  • 4. 작은 따옴표 3개

print("[문자열 만드는 4가지 방법]") 
print("1. happy day") 
print('2. happy day') 
print("""3. happy day""") 
print('''4. happy day''')

 

2. 이스케이프 문자

문자열 안에서 특수한 기능을 가지는 문자들이다. 역슬래시 기호(\)로 시작한다.

\n : 개행(줄바꿈) 
\t : tab키를 누른 만큼 간격 띄우기 
\\ : \ 하나를 문자로 사용 
\' : ' 하나를 문자로 사용 
\" : " 하나를 문자로 사용

 

3. 문자열 연산

 

  • + : 문자열을 연결한다.

  • * : 문자열을 반복한다.

print("안녕" + "하세요")

print("안녕" * 5)

 

4. 문자열 인덱싱

문자열에서 특정 순서(인덱스)의 글자를 뽑아낼 때 [ ](대괄호)를 사용한다.

exStr = "안녕하세요."

print(esStr[0], esStr[-1])

 

5. 문자열 슬라이싱

문자열의 인덱스로 특정 범위의 문자를 조각내서 사용할 때 이용한다.

a[0:3] --> 콜론(:)으로 범위 지정 
a[시작인덱스:끝인덱스] --> 끝인덱스는 포함 X 
a[시작인덱스:] --> '시작인덱스'부터 '끝'까지 
a[:끝인덱스] --> '처음'부터 '끝인덱스'까지 (끝인덱스는 포함 X) 
a[:] --> 시작부터 끝 --> 전체

문자열 슬라이싱에서 인덱스를 범위를 초과해도 오류가 나지 않는다. 그리고 만약 문자열 중 첫 글자를 바꾸고 싶다면 이미 만들어진 문자열은 수정이 불가능해서 mystr[0] = 'w' 같이 사용할 수 없다. 따라서 이미 만들어진 문자열은 변경이 불가능해 새로 만들어야 한다.

참고로 인덱싱과 슬라이싱은 문자열뿐 아니라, 하나의 자료가 여러 개의 값으로 이루어진 경우 모두 사용 가능하다.

여기서 문자열이란, 문자 하나하나가 나열된 자료이기에 인덱싱과 슬라이싱이 가능하다.

 

 

6. 문자열 포매팅

 

6-1. 포매팅 서식 문자를 이용한 방법

문자열 안에 값을 삽입하는 방법이다. 포매팅은 아래와 같은 서식 문자들을 사용한다.

%s -->문자열 (String) 
%c -->문자 1개 
%d -->정수 
%f -->실수 
%% -->% 하나를 문자로 삽입

 

다음과 같이 포매팅을 사용하면 된다.

 

1) 문자열 뒤에 바로 % 기호를 붙여서 값을 입력한다.

포맷 코드의 사용은 뒤에 오는 값을 어떤 형태로 삽입할지 결정한다.

print("정수 : %d" % 20) 
my_str = "정수 : %d" % 30 
print(my_str)

print("실수 : %f" % 10.1) 
print("문자열 : %s" % "나는 문자열")

print("정수 : %d" % 10.123) # 실수 값을 정수로 삽입(소수점은 없어짐) 
print("실수 : %f" % 30) # 정수 값을 실수로 삽입(없던 소수점 생김)

#print("정수 : %d" % "1") # 오류! 문자열을 숫자형태로 삽입 불가 
print("문자열 : %s" % 10) # %s는 전부 문자 취급 
print("문자열 : %s" % 10.123)

여러 개 포매팅을 할 경우, 소괄호로 묶어 순서대로 값을 삽입해주면 된다.

print("%d개 이상의 %s 넣기" % (2, "값"))

 

2) 포매팅으로 소수점 표현하기

실수는 기본 소수점 6자리까지 표현하고 그 이상은 자동으로 반올림한다.

print("소수 : %f" % 10.1) # 기본 6자리 
print("소수 : %f" % 10.666666666) # 자동 반올림

print("소수점 지정 : %.3f" % 10.66666666666666)

3) 포맷 코드를 이용한 정렬과 공백

print("[%s] [%s]" % ("파이썬", "재밌다")) 
print("[%10s] [%10s]" % ("파이썬", "재밌다")) # 삽입시 10칸 확보 후 값을 넣겠다. (우측정렬) 
print("[%-10s] [%-10s]" % ("파이썬", "재밌다")) # 삽입시 10칸 확보 후 값을 넣겠다. (좌측정렬)

 

6-2. 포매팅 함수를 이용한 방법(많이 사용하는 방법) - format()

format() 함수는 '문자열'로 사용할 수 있는 '문자열의 함수'이다.

1) 만든 문자열을 변수에 대입

my_str = "제 이름은 {}입니다.".format("홍길동") 
print(my_str)

 

2) 만든 문자열을 바로 출력

print("제 나이는 {}살 입니다.".format(20))

포맷 코드 대신 {} 중괄호를 사용한다. 마치 %s와 같다.

 

3) 여러 값 사용

print("1. 제 이름은 {}이고, {}살 입니다.".format("홍길동", 20)) # 기본은 순서대로 
print("2. 제 이름은 {1}이고, {0}살 입니다.".format("홍길동", 20)) # {}안에 인덱스 사용 
#출력
1. 제 이름은 홍길동이고, 20살 입니다. 
2. 제 이름은 20이고, 홍길동살 입니다.

 

4) 키워드 사용

print("제 이름은 {name}이고, {age}살 입니다.".format(name = "홍길동", age = 20))

 

5) 소수점 표현

print("소수점 3자리 : {:.3f}".format(10.777777))

#출력 
소수점 3자리 : 10.778 

format() 함수 사용 시 중괄호{} 안에 특수한 기능을 추가하는 기호로 콜론(:)을 사용한다.

콜론을 사용할 때는 인덱스 뒤에 위치한다. 여기서 인덱스는 생략이 가능하다.

 

6) 정렬

print("[{}] [{}]".format("파이썬", "재밌다")) 
print("[{:10}] [{:10}]".format("파이썬", "재밌다")) # 10칸 확보, 기본 좌측정렬 
print("[{:>10}] [{:>10}]".format("파이썬", "재밌다")) # 우측정렬 > 
print("[{:<10}] [{:<10}]".format("파이썬", "재밌다")) # 좌측정렬 < 
print("[{:^11}] [{:^11}]".format("파이썬", "재밌다")) # 가운데 정렬 ^ 

print("[{:*^11}] [{:=^11}]".format("파이썬", "재밌다")) # 정렬 후 빈 공간에 값 채우기(단, 1개의 문자로만 채울 수 있다.)
#출력

[파이썬] [재밌다] 
[파이썬       ] [재밌다       ] 
[       파이썬] [       재밌다] 
[파이썬       ] [재밌다       ] 
[    파이썬    ] [    재밌다    ] 
[****파이썬****] [====재밌다====]
# 출력 방법 비교 
print("제 이름은 " + name + "이고,", age, "살 입니다.", sep='')# (1) 포매팅 X 경우 
print("제 이름은 %s이고, %d살 입니다." % (name, age)) # (2) 기본 포매팅 
print("제 이름은 {}이고, {}살 입니다.".format(name, age)) # (3) 포매팅함수

 

 

반응형

 파이썬 기초 문법 - 자료형 

 

1. 숫자 자료형

 

파이썬의 숫자 자료형은 '정수, 실수형, 2진수, 8진수, 16진수'로 표현할 수 있다.

'''
        정수           : -10, 0, 10
        실수형         : -1.1, 10.123
        2진수(binary)  : 0b10, 0B10
        8진수(octal)   : 0o10, 0O10
        16진수(hexadecimal) : 0x10, 0X10
'''

아래에 간단한 예제를 보자.

print("[기본 숫자형]")
print("정수 :", 10, -10, 0)
print("실수 :", -1.1, 10.123)
# print() 함수는 숫자를 10진수로 출력
print("2진수 :", 0b100, 0B100)
print("8진수 :", 0o10, 0O10)
print("16진수 :", 0x10, 0X10)

결과는 다음과 같다.

정수 : 10 -10 0
실수 : -1.1 10.123
2진수 : 4 4
8진수 : 8 8
16진수 : 16 16

 

 

2. 문자열

 

파이썬에서 문자열을 만드는 방법은 4가지가 있다.

  • 1. 큰 따옴표 1개

  • 2. 작은따옴표 1개

  • 3. 큰 따옴표 3개

  • 4. 작은 따옴표 3개

print("1. happy day")
print('2. happy day')
print("""3. happy day""")
print('''4. happy day''')

결과는 다음과 같다.

1. happy day
2. happy day
3. happy day
4. happy day

만약 여러 줄의 문자열을 출력하고 싶다면 따옴표 3개짜리를 이용하면 된다.

print("""안녕하세요
파이썬입니다.""")

hello = '''반가워요
파이썬!'''
print(hello)

문자열을 사용하고 출력할 때 사용되는 '이스케이프 문자'가 있는데, 이스케이프 문자는 문자열 안에서 특수한 기능을 가지는 문자들을 말한다. 이스케이프 문자는 역슬래시(\)로 시작해 사용한다. 아래에 여러 이스케이프 문자들이 있다.

'''
	\n : 개행(줄바꿈)
	\t : tab키를 누른 만큼 간격 띄우기
	\\ : \ 하나를 문자로 사용
	\' : ' 하나를 문자로 사용
	\" : " 하나를 문자로 사용
'''

 

 

문자열 연산하기

문자열을 연산할 때 주의할 것이 문자열끼리만 연산이 가능하다는 것이다. 예를 들어 정수와 문자열 사이의 연산을 하게 되면 오류가 발생한다. 그러니 이 점을 주의해서 사용해야 한다.

문자열 연산은 2가지 경우가 있다.

#1. + : 연결
print("안녕" + "하세요")
str1 = "안녕"
str2 = "하세요"
print(str1 + str2)

#2. * : 반복
print("안녕" * 5)
str3 = "곱셈" * 3 # 연산 결과를 만든 후 변수에 대입
print(str3)

 

 

문자열 인덱싱(Indexing)

인덱싱(Indexing)이란 index 색인, '무언가를 가리킨다'는 것으로, 문자열에서 특정 글자를 뽑아내어 사용하는 것이다. 특정 글자를 찾을 때, '순서'를 사용하는데 이 때 인덱스 번호를 이용한다. 프로그래밍에서 순서는 0부터 시작을 하며 음수일 경우 뒤에서부터 순서를 세는 방식이다.

 

 

문자열 슬라이싱

문자열 슬라이싱은 문자열은 원하는 길이만큼 조각내는 것이다. 인덱스로 특정 범위의 문자를 조각내서 사용한다. 아래처럼 다양하게 사용할 수 있다.

a[0:3] --> 콜론(:)으로 범위 지정

a[시작 인덱스:끝 인덱스] --> 끝 인덱스는 포함 X

a[시작 인덱스:] --> '시작 인덱스'부터 '끝'까지

a[:끝 인덱스] --> '처음'부터 '끝 인덱스'까지 (끝 인덱스는 포함 X)

a[:] --> 시작부터 끝 --> 전체

 

 

문자열 기본 포매팅

 

문자열 포매팅은 문자열 안에 '값'을 '삽입'하는 방법이다. 포매팅 코드(서식문자)는 4가지가 있다.

%s - 문자열 (String)
%c - 문자 1개
%d - 정수
%f - 실수
%% - % 하나를 문자로 삽입

서식 문자를 사용한 문자열 포매팅 예제들입니다.

# 문자열 뒤에 바로 % 기호를 붙여서 값을 입력
print("정수 : %d" % 20)
my_str = "정수 : %d" % 30
print(my_str)
print("실수 : %f" % 10.1)
print("문자열 : %s" % "나는 문자열")

print("정수 : %d" % 10.123) # 실수 값을 정수로 삽입(소수점은 없어짐)
print("실수 : %f" % 30) # 정수 값을 실수로 삽입(없던 소수점 생김)

print("문자열 : %s" % 10) # %s는 전부 문자 취급
print("문자열 : %s" % 10.123)
#결과
정수 : 20
정수 : 30
실수 : 10.100000
문자열 : 나는 문자열
정수 : 10
실수 : 30.000000
문자열 : 10
문자열 : 10.123

다음으로 포맷 코드 대신 format() 함수를 이용한 문자열 포매팅 방법입니다.

my_str = "제 이름은 {}입니다.".format("홍길동") # 만든 문자열을 변수에 대입
print(my_str)

name = "홍길동"
age = 20
print("제 이름은 {}이고, {}살 입니다.".format(name, age))

 

반응형

파이썬 기초 문법 

 

1. 주석(Comment)

 

  • 소스에 설명을 추가하는 것
  • 프로그램 수행에 영향이 없다.
  • 한 줄 주석 : # 뒤부터 주석 처리
  • 여러줄 주석 : ''' ''' 또는 """ """
    - 작은 따옴표 3개 또는 큰 따옴표 3개로 묶는다.
'''
	여러줄
    주석처리

'''
""" 
	여러줄
	주석처리 
"""

 

 

2. 문자열 (String)

 

파이썬의 기초 자료형 중의 하나로 문자의 나열을 말한다. 문자열을 만들려면 "abc"나 'abc' 처럼 따옴표로 묶는다.

str1 = "파이썬 Python"
str2 = "1234"

 

 

3. print( ) 함수

 

화면으로 데이터(숫자, 문자열 등)를 출력하는 함수


- 함수 : 특정 행위를 하기 위해 미리 만들어 놓은 기능

- 화면 : IDLE이나 콘솔(cmd.exe)

- 구분기호 : 콤마(,)로 값을 나열할 때 값을 구분하는 기호로 기본 값은 공백(sep = ' ') 이다.

 

print(1, 2, 3, sep = ' ')
print(1, 2, 3, sep = '') # 직접 지정 가능
print(1, 2, 3, sep = '하') 
# 출력
1 2 3
1 2 3
123
1하2하3

 

- 마지막기호 : print( ) 함수의 출력이 끝나면 출력하는 기호로 값은 '개행(줄바꿈) (end = \n)'    이다. 여기서 \n은 줄바꿈을 의미하는 특수한 문자(이스케이프 문자)이다.

 

print("안녕") # end를 따로 입력하지 않으면 기본이 개행
print("하세요", end = '\n')
print("안녕", end = '') # 직접 지정 가능
print("하세요", end = '하하하')
# 출력
안녕
하세요
안녕하세요하하하

 

- print( ) 함수에서 사용되는 기본적인 연산자

  + 기호 , 기호
용 도 연 산 --> 하나의 값을 만든다 나 열 --> 여러 값을 나열한다
print(1 + 2) # 숫자 + 숫자 ==> 덧셈 연산
print("1 + 2 =", 1 + 2)
print("1" + "2") # 문자열 + 문자열 ==> 문자연결 (하나의 문자를 만든다.)
print("1" "2") # 문자열끼리는 기호 없이 연결 가능
# 출력
3
1 + 2 = 3
12 # 정수 숫자가 아닌 문자열임
12 # 문자열

 

 

 

4. 변수 (Variable)

 

- 값을 저장하는 공간, 파이썬에서 사용하는 변수는 값을 '저장' 하는 개념이 아니라 값을 '가리킨다.'

- 프로그래밍 언어에서 = (equl, 등호) 기호는 '같다'가 아닌 '대입'으로 우변의 값을 좌변에 대입하는 것이다.

- 파이썬에서 변수를 만들때 변수명 앞에 따로 자료형(정수, 실수, 문자열 등)을 표시를 하지 않는다

- 변수명 규칙

 

① 한글 사용 가능 --> 그래도 영어로 한다.


② 특수문자(기호)는 _만 사용


③ 대소문자 구분


④ 숫자 사용 가능, 단 첫 글자로는 안된다.


⑤ 예약어 사용 불가

- 이미 시스템에서 사용하고 있는 단어
- 색상이 들어간 단어 사용금지

 

⑥ 변수명을 지을 때 의미를 부여

- 변수명만 봐도 어떤 값을 사용하는지 알 수 있도록

# 변수명 짓기 예시
#숫자 --> num1, num2, ...
#문자열 --> str1, str2, ...
#점수 --> Score1, Score2, ...
#학생 점수 --> StudentScore1, StudentScore2, ...

 

- 변수에 값 대입

# 변수에 값 대입 (1) - 하나씩
a = 1 # a라는 변수에 1을 대입
b = "2"
c = 3

print(a, b, c) # 각 변수가 가리키고 있는 값을 사용

# 변수에 값 대입 (2) - 한 번에
a, b, c = 4, 5, 6 # 순서대로 대입, 짝이 맞아야 된다.
print(a, b, c)

# 변수에 값 대입 (3) - 모두 같은 값
a = b = c = 7
print(a, b, c)
# 출력
1 2 3
4 5 6
7 7 7

 

반응형

+ Recent posts