1.格式字符串
在字符串中通过格式 占位符来表示字符串中变化的部分
语法:包含格式占位符 % (给格式占位赋值的数据列表)
说明:
格式占位符:%s - 字符串
%d - 整数
%.nf - 浮点数,n/N可以约束小数点后面的小数位数(正整数)
%c - 字符,可以将整数转换为字符
%x - 将十进制数字转换为十六进制,x的大小写在转换中可以决定转换后出现的字母的大小写
name = input('姓名:')
age = int(input('年龄:'))
message = name + '今年' + str(age) + '岁'
print(message)
message = '%s今年%d岁,月薪:%f,等级:%c,%X' % (name,age,10000,97,12)
print(message)
message = '%s今年%d岁,月薪:%.2f,等级:%c,%x' % (name,age,10000,'a',12)
print(message)
2.常用的对象方法
字符串1.count(字符串2) - 统计字符串2在字符串1中出现的次数
str1 = 'and you? how are you!'
print(str1.count('you'))
1)字符串1.find(字符串2) - 在字符串1中查找字符串2第一次出现的位置,如果找不到返回-1,找到了返回第一个字符的下标
字符串1.find(字符串2,开始下标,结束下标) - 在字符串1中开始下标到结束下标范围内查找字符串2第一次出现的位置
2)字符串1.find(字符串2) - 在字符串1中查找字符串2第一次出现的位置, 如果找不到返回-1, 找到了返回第一个字符的下标
字符串1.find(字符串2, 开始下标,结束下标) - 在字符串1中开始下标到结束下标的范围内查到字符串2第一次出现的位置(不包含结束下标)
str1 = 'and you? how are you!'
print(str1.find('you'))
print(str1.find('you', -8))
3)index的功能和find一样,只是如果字符串2不存在的时候会报错
str1 = 'and you? how are you!'
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']))
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'))
3.列表
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 = [10,39,23,80,23]
name = ['张三','李四']
4.查 - 获取列表元素
获取单个元素(和字符串一样):list[下标]
names = ['海贼王','火影忍者','死神','犬夜叉','妖精的尾巴','熊出没','一人之下']
print(names[-2]) # 熊出没
获取部分元素-切片(和字符串一样):列表[开始下标;结束下标:步长]
列表切片的结果是列表
print(names[1:4]) # ['火影忍者', '死神', '犬夜叉']
print(names[1:4:-1]) # []
print(names[::-1]) # ['一人之下', '熊出没', '妖精的尾巴', '犬夜叉', '死神', '火影忍者', '海贼王']
print(names[:]) # 相当于拷贝 ['海贼王', '火影忍者', '死神', '犬夜叉', '妖精的尾巴', '熊出没', '一人之下']
print(names[::2]) # ['海贼王', '死神', '妖精的尾巴', '一人之下']
5.遍历
''''''
a.直接遍历
for 变量 in 列表:
循环体
b.通过下标遍历
for 变量 in range(len(列表)): # 变量取到的是下标
循环体
"""
for item in list1:
print(item)
for index in range(0,len(names),2):
print(index,names[index])
将班级学生的成绩保存到scores中,求班级的平均成绩和不及格人数
scores = [90,80,70,100,76,57,54]
scores = [90,80,70,100,76,57,54]
num1 = 0
num2 = 0
sum1 = 0
for index in range(len(scores)):
num1 += 1
sum1 += int(scores[index])
if scores[index] < 60:
num2 +=1
n = sum1 / num1
print('平均成绩:%.1f,不及格人数:%d' % (n,num2))
补充:求和函数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(-100,22)
print(numbers)
numbers.insert(100,22)
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)
4).清空;列表.clear() - 删除列表中所有的元素
names.clear()
print(names)
7.改 - 修改列表元素
列表[下标] = 新值 - 将列表中指定下标对应的元素改成新值
nums =[1,2,3]
nums[0] = 100
print(nums)
- in/not in
元素 in 列表 --- 判断列表中是否包含指定的元素
print([1,2] in [1,2,3,4,5] ) # False
print(1 in [1,2,3]) # True