day9 字符和字符串

1. 什么是字符串(str)

"""
字符串是容器型數據類型, 將單引號或者雙引號作為容器的標志, 元素不需要用逗號隔開: '元素1元素2元素3...'
字符串是不可變的(不支持增刪改);字符串是有序的(支持下標操作)

字符串中的元素: 只能是文本符號(所有計算機能表達出來的符號都可以作為字符串的元素),一個符號對應一個元素
'湖北', 'abcn','!@#$%', '↑?', '123456'

字符串中每一個獨立的元素又叫:字符;python中只有字符的概念,但是沒有字符對應的數據類型
"""

空串

str1 = ''
str2 = ""
str3 = ''''''
str4 = """"""
print(type(str1), type(str2), type(str3), type(str4))

非空字符串

str11 = 'abc'
str22 = "你好"
str33 = '''你好,hello'''
str44 = """123,hai"""

2. 字符(字符串中的元素)

"""
字符串中的字符分兩種:普通字符、轉義字符
1)普通字符 - 除了轉義字符串以外的字符
2)轉義字符 - 在指定符號前加\用來表示一些特殊功能和特殊意義的字符
\n - 換行
\t - 制表符(按tab鍵)
' - 單引號
" - 雙引號
\ - 反斜杠
"""

編碼字符:\u4位的十六進制

str1 = '\tabc\n123'
print(str1)

str2 = 'abc'123'
str3 = "abc"123"
str4 = 'abc\n123'
print(str4)

這兒 \u4e00 和 \u7800 都是轉義字符中的編碼字符

str5 = '\u4e00你好!\u7800'
print(str5, len(str5))

注意: 計算字符串長度的時候,一個轉義字符的長度是1

"""

  1. 阻止轉義(r語法)
    在字符串的最前面加 r/R , 那么這個字符串中的所有的轉義字符都無效
    """
    str6 = r'\tabc\n123\u4e00'
    print(str6)

應用1:windows路徑

path = r'c\nan\temp'
print(path)

應用2:正在表達式式

1.什么是字符編碼

計算機在存儲數據的時候只能存數字,而且存的是數字的補碼

"""
為了能夠讓計算機存儲文本數據,給每個字符關聯了一個固定的數字,用來對這個字符進行存儲。每個字符關聯的那個數字就是這個字符的編碼值。
"""

2. 編碼表

"""
1)ASCII碼表:用1個字節來對字符進行編碼(碼值范圍:0 ~ 127)
a.數字在字母的前面(字符0~字符9的編碼值連續遞增)
b.大寫字母在小寫字母的前面(字母之間是連續遞增)
c.大寫字母和小寫字母之間有其他的符號(不連續)

2)Unicode編碼表
Unicode編碼表是對ASCII表的擴展(Unicode編碼表中包含了ASCII表中所有的符號)
Unicode編碼表中包含了世界上所有國家所有民族所有的語言的符號,總共65536個
中文范圍:4e00 ~ 9fa5
"""

1)chr函數

"""
chr(編碼值) - 獲取指定編碼值對應的字符
"""
print(chr(0x0F00))
for x in range(0x0F00, 0x0FFF):
print(chr(x), end=',')
print()

打印所有的中文

count = 0
for x in range(0x4e00, 0x9fa5):
print(chr(x), end=' ')
count += 1
if count % 40 == 0:
print()
print()

2) ord函數

"""
ord(字符) - 獲取指定字符對應的編碼值
"""
print(ord('余'), ord('婷'))

3) 編碼字符

str1 = '\u4e00你好!'
print(str1)

1. 獲取字符串中的元素(獲取字符)

字符串獲取元素和列表獲取元素的語法一樣

str1 = 'how are you!'

1)獲取單個元素

print(str1[2])
print(str1[-1])

2) 切片

print(str1[1:5]) # 'ow a'
print(str1[-3::-1]) # 'oy era woh'

3) 遍歷

for x in str1:
print(x)

for index in range(len(str1)):
print(str1[index])

2. +, *

"""
字符串1 + 字符串2
字符串 * N / N * 字符串
"""
str1 = 'abc'
str2 = '123'
print(str1 + str2) # abc123
print(str1 * 2) # abcabc

3. ==, !=

print(str1 == 'abc') # True
print(str1 == 'bac') # False

4. >, <, >=, <= (針對兩個字符串)

"""
兩個字符串比較大小: 比較的是第一組不相等的字符的編碼值的大小
"""
str3 = 'zABC'
str4 = 'z1bcd'
print(str3 > str4) # True

"""
應用:
判斷是否是數字字符: '0' <= char <= '9'
判斷是否是小寫字母:'a' <= char <= 'z'
判斷是否是大寫字母:'A' <= char <= 'Z'
判斷是否是字母:'a' <= char <= 'z' or 'A' <= char <= 'Z'
判斷是否是中文字符: '\u4e00' <= char <= '\u9fa5'
"""

練習1:輸入一個字符串,統計字符串中字母和中文的個數

str6 = 'hello, 你好嗎?'
count1 = 0
count2 = 0
for x in str6:
if 'a' <= x <= 'z' or 'A' <= x <= 'Z':
count1 += 1
elif '\u4e00' <= x <= '\u9fa5':
count2 += 1
print('字母的個數:', count1, '中文的個數:', count2)

練習2:判斷輸入的字符串是否是純數字字符串

str7 = '728373'
for x in str7:
if not '0' <= x <= '9':
print('不是純數字字符串')
break
else:
print('是純數字字符串')

5. in 和 not in

"""
字符串1 in 字符串2 - 判斷字符串1是否是字符串2的子串
"""
print('abc' in 'acbmn') # False
print('abc' in 'abcmn') # True
print('m' in 'abcmn') # True

6.相關函數

"""
max/min/sorted/reversed等,這些函數都適用于字符串

len(字符串) - 求字符串長度

str(數據) - 將自定數據轉換成字符串
a.所有的數據都能轉換成字符串
b.將數據的打印值作為字符串的內容
"""
str1 = r'\tabc'
print(len(str1)) # 5

num = 100
str(num) # '100'

str([1, 2, 3]) # '[1, 2, 3]'

1. center/rjust/ljust/zfill

"""
字符串.center(長度, 填充字符) - 產生一個新的字符串:長度是指定的長度,原字符串在新字符串的中間,左右用指定字符填充
字符串.rjust(長度, 填充字符) - 產生一個新的字符串:長度是指定的長度,原字符串在新字符串的最右邊,左邊用指定字符填充
字符串.zfill(長度) == 字符串.rjust(長度, '0')
字符串.ljust(長度, 填充字符) - 產生一個新的字符串:長度是指定的長度,原字符串在新字符串的最左邊,右邊用指定字符填充
"""
str1 = 'abc'
new_str1 = str1.center(7, 'x')
print(new_str1) # xxabcxx

new_str2 = str1.rjust(7, '*')
print(new_str2) # ****abc

new_str2 = str1.ljust(7, '*')
print(new_str2) # abc****

練習1: 給任意一個商品的數字編號值,轉換成固定格式的商品編碼: GDXXXX -> GD0001, GD0012,....

num = 2 # 0034
num_str = 'GD'+str(num).zfill(4)
print(num_str)

2. replace

"""
字符串1.replace(字符串2, 字符串3) - 將字符串1中所有的字符串2全部替換成字符3
字符串1.replace(字符串2, 字符串3, N) - 將字符串1中的前 N 個字符串2替換成字符串3
"""
str1 = 'how are you? i am fine, Thank you!'
new_str = str1.replace('o', '')
print(new_str) # h
w are yu? i am fine, Thank yu!

new_str = str1.replace('o', '+', 2)
print(new_str) # h+w are y+u? i am fine, Thank you!

new_str = str1.replace('you', 'me')
print(new_str) # how are me? i am fine, Thank me!

?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。