day7总结

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)
  1. in/not in
    元素 in 列表 --- 判断列表中是否包含指定的元素
print([1,2] in [1,2,3,4,5] )    #  False
print(1 in [1,2,3])      # True

你可能感兴趣的:(day7总结)