day-7 list

1. 用''或者""引起来的字符集

2.str - 不可变(不支持增删改)、有序(支持下标语法)

3.字符: 普通字符、转义字符(\n、\t、'、"、\) - 阻止转义r/R、编码字符

str1 = 'abc'
new_str1 = str1.capitalize()
print(new_str1, str1)

str2 = r'\nabc\\'
print(str2)

str3 = '\u45ff'
print(str3)

4.获取字符

字符串[下标]

字符串[开始下标:结束下标:步长]

str4 = 'abcdef1234'
print(str4[2], str4[-1])
print(str4[2:-1:2])
print(str4[3:1:-1])
print(str4[1:-2])
print(str4[::-1])

遍历

"""
for 变量 in 字符串:
循环体

for 变量 in range(len(字符串)):
循环体
"""

5.相关运算

+,: 字符串1+字符串2, 字符串1N

# >,<,>=,<=  ==  !=
# '0'<=char<='9'
print('accdef' > 'abcf' )

6.内置函数

len(序列),str()

num = 2386
print(len(str(num)))
print(str(num)[::-1])

7. in / not in

print('sb' not in 'sb安徽省 数据')

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)

练习: 输入学生姓名、年龄、和性别, 以'XX今年X岁,性别: X'的格式打印学生信息

2.常用对象方法

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阅读 213,752评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,100评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,244评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,099评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,210评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,307评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,346评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,133评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,546评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,849评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,019评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,702评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,331评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,030评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,260评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,871评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,898评论 2 351

推荐阅读更多精彩内容