day7

1.格式字符串: 在字符串中通过格式占位符来表示字符串中变化的部分

语法: 包含格式占位符的字符 % (给格式占位赋值的数据列表)

说明:

"""
格式占位符: %s - 字符串
          %d -  整数
          %.Nf -  浮点数, N可以约束小数点后面的小数位数(正整数)
          %c - 字符, 可以将整数转换为字符
          %x/X   - 整数(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) - 统计字符串2在字符串1中出现的次数

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

1: 打印字符串中每个字符出现的次数打印字符串中出现次数最多字符和对应的次数'how are you?oh~' 打印: o 3次

print('==========练习1============')
str1 = 'how are you?oh~'
max_count = 0    # 保存当前最大次数
max_char = ''    # 保存当前最大次数对应的字符
for char in str1:
    # 获取每个字符出现的次数
    count = str1.count(char)
    # 如果获取的字符的次数,比最大次数还大,说明这次次数才是最新的最次数,对应的字符就是最新的最大次数的字符
    if count > max_count:
        max_count = count
        max_char = char
print('%s出现%d次' % (max_char, max_count))

2)字符串1.find(字符串2) - 在字符串1中查找字符串2第一次出现的位置, 如果找不到返回-1, 找到了返回第一个字符的下标

字符串1.find(字符串2, 开始下标,结束下标) - 在字符串1中开始下标到结束下标的范围内查到字符串2第一次出现的位置(不包含结束下标)

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

2: 在字符串中'and you? how are you! you',找到所有'you'出现的下标。 打印: 4, 17, 22

print('==============练习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中是否只有数字字符

print('83'.isdigit())

5)字符串1.isnumeric() - 判断字符串1是否是数字字符串(可以检查中文数字)

print('壹仟'.isnumeric())

6)字符串1.join(序列) - 将序列中的元素用字符串1连接在一起产生一个新的字符串

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

3: 自己实现join的功能, 给字符串1, 和字符串2,用字符串1将字符串2中的所有的字符串连接起来例如: str1 = 'aaa', str2 = '123', 输出: '1aaa2aaa3'

print('============练习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.什么时候用列表: 需要用一个变量去同时保存多个数据

2.什么是列表(list)

"""
列表是python内置的容器型数据类型(序列), 可变(说明支持曾删改)并且有序(支持下标操作)  
用中括号将多个元素括起来,多个元素之间用逗号隔开: [元素1,元素2,元素3...]
"""

3.列表中元素: python内置的数据类型对应的数据,或者是程序员自定义类型的数据都可以;不同元素的类型可以不一样注意: 赋值运算表达式不能作为列表元素,其他的都可以

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])

获取部分元素-切片(和字符串一样): 列表[开始下标:结束下标:步长]

列表切片的结果是列表

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

遍历

"""
a.直接遍历  
for 变量 in 列表:       # 变量取到的是元素
    循环体
    
b.通过下标遍历
for 变量 in range(len(列表)):      # 变量取到的是下标
    循环体
"""
for item in names:
    print(item)

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

练习: 将班级学生的成绩保存到scores中,求班级的平均成绩,和不及格人数

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 不及格人数:%d' % (sum1/len(scores), count))
# 补充:  求和函数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)

练习: 输入一个数字,将它添加到一个有序列表中,要求添加进去后不改变从小到大或者从大到小排列的顺序[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('请输入一个数字:'))
"""
# 思路: 找到第一个比输入的数字大的数字对应的下标,然后插入到这个下标前。如果原来的数字都比输入的小,就添加到最后
for index in range(len(numbers)):
    if numbers[index] > num:
        numbers.insert(index, num)
        break
else:
    numbers.append(num)

print(numbers)
"""

6.删 - 删除元素

1) del 列表[下标] - 将指定列表中指定下标对应的元素删除

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

2) 列表.remove(元素) - 将指定列表中第一个指定元素删除注意:如果元素不存在,会报错

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

3)

列表.pop() - 移除列表中最后一个元素, 返回被移除的元素
列表.pop(下标) - 移除列表中指定下标对应的元素, 返回被移除的元素

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.改 - 修改列表元素

"""
列表[下标] = 新值   - 将列表中指定下标对应的元素改成新值
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
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352

推荐阅读更多精彩内容