day7

1.格式字符串: 在字符串中通過格式占位符來表示字符串中變化的部分

語法: 包含格式占位符的字符 % (給格式占位賦值的數(shù)據(jù)列表)

說明:

"""
格式占位符: %s - 字符串
          %d -  整數(shù)
          %.Nf -  浮點數(shù), N可以約束小數(shù)點后面的小數(shù)位數(shù)(正整數(shù))
          %c - 字符, 可以將整數(shù)轉(zhuǎn)換為字符
          %x/X   - 整數(shù)(16進制)
          
"""

# name = input('姓名:')
# age = int(input('年齡:'))
# message = '%s今年%d歲,月薪:%.2f 等級:%c ,%x' % (name, age, 10000, 65, 12)
# # message = name+'今年'+str(age)+'歲'
# print(message)

.常用對象方法

1)字符串1.count(字符串2) - 統(tǒng)計字符串2在字符串1中出現(xiàn)的次數(shù)

str1 = 'and you? how are you!'
print(str1.count('you'))

1: 打印字符串中每個字符出現(xiàn)的次數(shù)打印字符串中出現(xiàn)次數(shù)最多字符和對應(yīng)的次數(shù)'how are you?oh~' 打印: o 3次

print('==========練習(xí)1============')
str1 = 'how are you?oh~'
max_count = 0    # 保存當前最大次數(shù)
max_char = ''    # 保存當前最大次數(shù)對應(yīng)的字符
for char in str1:
    # 獲取每個字符出現(xiàn)的次數(shù)
    count = str1.count(char)
    # 如果獲取的字符的次數(shù),比最大次數(shù)還大,說明這次次數(shù)才是最新的最次數(shù),對應(yīng)的字符就是最新的最大次數(shù)的字符
    if count > max_count:
        max_count = count
        max_char = char
print('%s出現(xiàn)%d次' % (max_char, max_count))

2)字符串1.find(字符串2) - 在字符串1中查找字符串2第一次出現(xiàn)的位置, 如果找不到返回-1, 找到了返回第一個字符的下標

字符串1.find(字符串2, 開始下標,結(jié)束下標) - 在字符串1中開始下標到結(jié)束下標的范圍內(nèi)查到字符串2第一次出現(xiàn)的位置(不包含結(jié)束下標)

print(str1.find('you'))
print(str1.find('you', -8))

2: 在字符串中'and you? how are you! you',找到所有'you'出現(xiàn)的下標。 打印: 4, 17, 22

print('==============練習(xí)2===============')
str1 = 'and you? how are you! you'
str2 = 'you'
start_index = 0
while True:
    index = str1.find(str2, start_index)
    if index == -1:
        break
    else:
        print(index, end=',')
    # 更新開始下標
    start_index = index + len(str2)
print()

3)index的功能和find一樣,只是如果字符串2不存在的時候會報錯 print(str1.index('you2'))

4)字符串1.isdigit() - 判斷字符串1中是否只有數(shù)字字符

print('83'.isdigit())

5)字符串1.isnumeric() - 判斷字符串1是否是數(shù)字字符串(可以檢查中文數(shù)字)

print('壹仟'.isnumeric())

6)字符串1.join(序列) - 將序列中的元素用字符串1連接在一起產(chǎn)生一個新的字符串

print('*'.join('abc'))
print('++'.join(['abc', 'bb', 'hhhh']))

3: 自己實現(xiàn)join的功能, 給字符串1, 和字符串2,用字符串1將字符串2中的所有的字符串連接起來例如: str1 = 'aaa', str2 = '123', 輸出: '1aaa2aaa3'

print('============練習(xí)3=============')
str1 = 'aaa'
str2 = '123'
# 方法1
str3 = ''
for char in str2:
    str3 += char + str1
print(str3[:-len(str1)])

# 方法2
str3 = ''
for index in range(len(str2)):
    if index == len(str2) - 1:
        # 如果是最后一個字符就不拼str1
        str3 += str2[index]
    else:
        # 如果不是最后一個字符就拼接str1
        str3 += str2[index] + str1
print(str3)
# str2 = 'ag23bsh2390s', str1 = '+'   -> 2+3+2+3+9+0

7)max(序列), min(序列) - 求序列中元素的最大值和最小值

print(max('ahsjdzddd'))
print(min('ahsskdz'))
print(min([120, 9, 99, -10]))

8)字符串1.replace(old,new) -- 將字符串1中的指定的老的字符串替換成新字符串

print('absasda'.replace('a', 'A', 2))

9)字符串1.split(字符串2) - 在字符串1把字符串2作為切點,將字符串1切割

print('shsjsj111askdhfkj111aksfk111nnmm'.split('111'))

1.什么時候用列表: 需要用一個變量去同時保存多個數(shù)據(jù)

2.什么是列表(list)

"""
列表是python內(nèi)置的容器型數(shù)據(jù)類型(序列), 可變(說明支持曾刪改)并且有序(支持下標操作)  
用中括號將多個元素括起來,多個元素之間用逗號隔開: [元素1,元素2,元素3...]
"""

3.列表中元素: python內(nèi)置的數(shù)據(jù)類型對應(yīng)的數(shù)據(jù),或者是程序員自定義類型的數(shù)據(jù)都可以;不同元素的類型可以不一樣注意: 賦值運算表達式不能作為列表元素,其他的都可以

list1 = [120, 12.9, True, 'abc', [1, 2, 3], {'a': 10}, lambda x: x*10]
print(list1)
num1 = 10
list2 = [num1, 100 + 200, 20 > num1]
print(list2)
scores = [90, 80, 70, 100, 76, 57, 54]
names = ['張三', '李四']

4.查 - 獲取列表元素

獲取單個元素(和字符串一樣): 列表[下標]

"""
names = ['海賊王', '火影忍者', '死神', '犬夜叉', '妖精的尾巴', '熊出沒', '一人之下']
"""

print(names[100]) # IndexError: list index out of range

print(names[-2])

獲取部分元素-切片(和字符串一樣): 列表[開始下標:結(jié)束下標:步長]

列表切片的結(jié)果是列表

print(names[1:4])    # ['火影忍者', '死神', '犬夜叉']
print(names[1:4:-1])     # []
print(names[::-1])    # ['一人之下', '熊出沒', '妖精的尾巴', '犬夜叉', '死神', '火影忍者', '海賊王']
print(names[:])       # ['海賊王', '火影忍者', '死神', '犬夜叉', '妖精的尾巴', '熊出沒', '一人之下']
print(names[::2])     # ['海賊王', '死神', '妖精的尾巴', '一人之下']

遍歷

"""
a.直接遍歷  
for 變量 in 列表:       # 變量取到的是元素
    循環(huán)體
    
b.通過下標遍歷
for 變量 in range(len(列表)):      # 變量取到的是下標
    循環(huán)體
"""
for item in names:
    print(item)

for index in range(0, len(names), 2):
    print(index, names[index])

練習(xí): 將班級學(xué)生的成績保存到scores中,求班級的平均成績,和不及格人數(shù)

scores = [90, 80, 70, 100, 76, 57, 54]
sum1 = 0
count = 0
for score in scores:
    sum1 += score
    if score < 60:
        count += 1
print('平均分是:%.1f 不及格人數(shù):%d' % (sum1/len(scores), count))
# 補充:  求和函數(shù)sum
# sum(序列)   - 求序列中所有元素的和;序列要求元素類型一致,并且元素支持求和運算
print(sum(scores), sum(range(101)))

5.增 - 添加元素

1) 列表.append(元素) - 在指定的列表的最后添加指定元素

persons = ['路飛', '寶兒姐', '張楚楠']
persons.append('容嬤嬤')
print(persons)
persons.append('趙云')
print(persons)

2) 列表.insert(下標,元素) - 在指定列表的指定下標前插入指定元素

numbers = [1, 20, 34, 50]
numbers.insert(2, 22)
print(numbers)
numbers.insert(0, 1000)
print(numbers)

練習(xí): 輸入一個數(shù)字,將它添加到一個有序列表中,要求添加進去后不改變從小到大或者從大到小排列的順序[1, 20, 100, 200] 輸入: 50 [1, 20, 50,100, 200]; 輸入:0 [0, 1, 20, 100, 200]輸入: 500 [1, 20, 100, 200, 500]

numbers = [1, 20, 100, 200]
num = int(input('請輸入一個數(shù)字:'))
"""
# 思路: 找到第一個比輸入的數(shù)字大的數(shù)字對應(yīng)的下標,然后插入到這個下標前。如果原來的數(shù)字都比輸入的小,就添加到最后
for index in range(len(numbers)):
    if numbers[index] > num:
        numbers.insert(index, num)
        break
else:
    numbers.append(num)

print(numbers)
"""

6.刪 - 刪除元素

1) del 列表[下標] - 將指定列表中指定下標對應(yīng)的元素刪除

names = ['海賊王', '火影忍者', '死神', '犬夜叉', '妖精的尾巴', '熊出沒', '一人之下', '海賊王']
del names[2]
print(names)

2) 列表.remove(元素) - 將指定列表中第一個指定元素刪除注意:如果元素不存在,會報錯

names.remove('海賊王')
print(names)

3)

列表.pop() - 移除列表中最后一個元素, 返回被移除的元素
列表.pop(下標) - 移除列表中指定下標對應(yīng)的元素, 返回被移除的元素

names = ['海賊王', '火影忍者', '死神', '犬夜叉', '妖精的尾巴', '熊出沒', '一人之下', '海賊王']
del_name = names.pop()
print(names, del_name)

del_name = names.pop(1)
print(names, del_name)
"""
# 需求: 刪除所有的指定元素,例如:'海賊王'
# names = ['海賊王', '火影忍者', '海賊王','死神', '熊出沒','犬夜叉', '妖精的尾巴', '熊出沒', '一人之下', '海賊王']
# 要求: 用remove, 用del/pop
"""

4) 清空: 列表.clear() - 刪除列表中所有的元素

names.clear()
print(names)

7.改 - 修改列表元素

"""
列表[下標] = 新值   - 將列表中指定下標對應(yīng)的元素改成新值
nums = [1, 2, 3]
nums[0] = 100
print(nums)
"""

8. in / not in

元素 in 列表 -- 判斷列表中是否包含指定的元素

print([1, 2] in [1, 2, 3, 4, [1, 2]])   # True
print([1, 2] in [1, 2, 3, 4])   # False
print(1 in [[1], 2, 3])   # False
print(1 in [1, 2, 3])    # True
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • “小賀,你記得今天跟小白確認一下她們明天來的時間,好去接飛機?!编噦愖谲嚿?,一邊給楊紫發(fā)微信,一邊囑咐小...
    荔枝酒一杯閱讀 404評論 0 0
  • 鉆進靈魂中的那個自己它才是自己2019.1.17
    時光美好怎能荒廢閱讀 98評論 0 0
  • 作者:杰克.韋爾奇 目錄: 第一章:讓使命、行動和結(jié)果協(xié)同起來 第二章:用五張幻燈片制定戰(zhàn)略 第三章:提升領(lǐng)導(dǎo)力的...
    Vinayan閱讀 1,366評論 0 2
  • 這是一場別人的夢境 今天是讀書第八天,每天都要趕上進度,在群里看別人對一些細節(jié)的討論,漸漸有些不厭其煩,你們討論那...
    jiangxinq閱讀 120評論 0 0

友情鏈接更多精彩內(nèi)容