概述
day7 - 日志和作业
名 | 作用 |
---|---|
in | 里面 |
not in | 不在里面 |
sum(列表) | 求和 |
max(列表) | 求最大值 |
min(列表) | 求最小值 |
sorted(列表) | 从小到大排序 |
reverse = True | 从大到小排序 |
list(数据) | 转换成列表 |
列表.clear() | 清空列表 |
列表.copy() | 复制列表 |
列表.count() | 统计元素个数 |
列表.extend(序列) | 将序列中的所有元素添加到列表中 |
列表.index(元素) | 获取元素在列表中对应下标 |
列表.reverse() | 倒叙 |
sort | 排序 |
一. 列表相关操作
-
数学运算符:+ 、*
-
列表1+列表2
将两个列表合并成一个新的列表
-
列表 * N、 N * 列表
将列表中的元素重复N产生一个新的列表
-
-
比较运算符:< , > , <= ,>= ,== ,!=
- 比较相等:==,!=
- 比较大小:>,<,<=,>=
- 两个列表比较大小,比较的是第一对不相等的元素大小
-
in 和not in
- 元素 in 列表 - 判断指定列表中是否存在指定元素
- 元素 not in 列表 - 判断指定列表中是否不存在指定元素
二.相关函数(系统函数)
-
sum(列表)
- 求列表中所有元素的和(列表必须是数字列表)
-
max(列表)/min(列表)
- 求列表中所有元素中的最大值/最小值
-
sorted(列表)
- 将列表中的元素从小打到大排序,产生一个新的列表
- sorted(列表,reverse = True):将列表中的元素从大到小排序,产生一个新的列表
-
list - 将其他数据装换成列表
- list(数据) - 将指定数据转换成列表(所有的序列都可以转换成列表:将其他序列转换成列表的时候直接将序列的元素作为列表的元素)
三.列表相关方法
-
clear
- 列表.clear() - 清空列表
-
copy
- 列表.copy() - 复制指定列表产生一个一样的新列表,将新的列表返回
- 原理:直接用一个变量给另外一个变量赋值,赋的地址,赋值后会导致两个变量同时指向同一块内存区域
- 列表[:],列表*1,列表+[]的功能和列表.copy()的功能一样
-
count
- 列表.count(元素) - 统计列表中指定元素的个数
-
extend
- 列表.extend(序列) - 将序列中所有的元素都添加到列表中
-
index
- 列表.index(元素) - 获取元素在列表中对应下标(返回是0开始的那个下标)
- 如果元素有多个,只返回最前面那个元素的下标
-
reverse
- 列表.reverse() - 倒叙
-
sort
- 列表.sort() -将列表元素从小到大排序
- 列表.sort(reverse=True) - 将列表元素从大到小排序
- sorted(列表) - 将列表元素从小到大排序,产生一个新的列表
- sorted(列表,reverse=True) - 将列表元素从小到大排序,产生一个新的列表
四.列表推导式
-
列表推导式 - 创建列表的表达式,主要用于对元素进行变换和筛选
-
结构1:[表达式 for 变量 in 序列]
原理:创建一个列表(让变量去序列中取值,一个一个的取,取一个值就计算一次表达式的结果并且将计算结果放入列表)
作用:将原序列中的元素按照指定规则(表达式)进行统一变换得到一个列表
-
结构2:[表达式 for 变量 in 序列 if 条件语句]
原理:将变量去序列中取值,一个一个的取,去一个值就判断一次条件语句是否成立,如果成立才计算表达式的结果,并且将结果作为序列的结果
-
五.元组
-
认识元组(tuple)
-
是容器;将()作为容器的标志里面多个元素用逗号隔开:(元素1,元素2,元素3,…)
-
不可变的(不支持增删改)
-
有序的
-
单个元素的元组:必须在唯一的元素后加逗号
-
-
元组就是不可变的列表
- 列表中和增删改无关的操作,元组都支持
- 查
- 切片
- len()获取元组元素数量
- 遍历
- 加法,乘法,比较,in,not in
- 相关函数:sum,max,min,len,sorted
- 部分相关方法:count、index
- 列表中和增删改无关的操作,元组都支持
-
元组不只是不可变的列表
- 单个元素的元组:(元素,)
- 在没有歧义的情况下,元组的()可以省略
- 获取元素的时候,可以让变量的个数和元组中元素一致
作业
- 创建一个列表,列表中有10个数字, 保证列表中元素的顺序,对列表进行排重,并对列表使用进行降序排序
例如:[70, 88, 91, 70, 107, 234, 91, 177, 282, 197]
--- 去重之后 [70, 88, 91, 107, 234, 177, 282, 197]
---- 降序排序 [282, 234, 197, 177, 107, 91, 88, 70]
print('n作业1')
li = [70, 88, 91, 70, 107, 234, 91, 177, 282, 197]
for _ in range(len(li)):
x = li.pop()
if x not in li :
li.insert(0,x)
print(sorted(li,reverse=True))
- 利用列表推导式, 完成以下需求
a. 生成一个存放1-100中各位数为3的数据列表
结果为 [3, 13, 23, 33, 43, 53, 63, 73, 83, 93]
print('n作业2a')
li = [x for x in range(1,101) if x % 10 == 3]
print(li)
b. 利用列表推到是将 列表中的整数提取出来
例如:[True, 17, "hello", "bye", 98, 34, 21] --- [17, 98, 34, 21]
print('n作业2b')
li = [True, 17, "hello", "bye", 98, 34, 21]
list_1 = [x for x in li if type(x == int)]
print(list_1)
c.利用列表推导式 存放指定列表中字符串的长度
例如: ["good", "nice", "see you", "bye"] --- [4, 4, 7, 3]
print('n作业2c')
append_1 = ["good", "nice", "see you", "bye"]
reverse_1 = [len(x) for x in append_1]
print(reverse_1)
d. 利用列表推导式删除列表中整数个位数小于5的元素
例如:[24, 'abc', 99, True, 21, 38, 'hello'] --- ['abc', 99, True, 38, 'hello']
print('n作业2d')
li = [24, 'abc', 99, True, 21, 38, 'hello']
li = [x for x in li if type(x) != int or (type(x) == int and x % 10 >=5)]
print(li)
e. 利用列表推导式获取元素是元组的列表中每个元组的最后一个元素
例如:[(10, 20, 30), ('abc', 'hello'), (1, 2, 3.4), (True, False)] --- [30, 'hello', 3.4, False]
print('n作业2e')
del_1 = [(10, 20, 30), ('abc', 'hello'), (1, 2, 3.4), (True, False)]
remove_1 = [x[-1] for x in del_1]
print(remove_1)
f.利用列表推导式将数字列表中所有的奇数乘以2,所有的偶数除以2
例如: [23, 4, 67, 88, 90, 21] -> [46, 2, 134, 44, 45, 42]
print('n作业2f')
insert_1 = [23, 4, 67, 88, 90, 21]
insert_2 = [2*x for x in insert_1 if x % 2 != 0]+ [x // 2 for x in insert_1 if x % 2 ==0]
print(insert_2)
-
已知一个列表获取列表中指定元素所有的下标
例如:[10, 20, 34, 10, 9, 78] 10的下标:[0, 3] 20的下标:[1] 30的下标:[]
print('n作业3') num7 = [10, 20, 34, 10, 9, 78] num = int(input("请输入元素:")) sub = [] if num in num7: for x, y in enumerate(num7): if num == y: sub.append(x) print(num, sub) else: print(num, sub)
-
*已知一个数字列表,写程序判断这个列表时候是连续递增列表。
例如: [1, 2, 3, 4, 5] -> True [23, 45, 78, 90] -> True [1, 3, 2, 4, 5] -> False
print('n作业4') A = [1, 2, 3, 4, 5] B = sorted(A) print(A == B)
-
已知两个列表,将两个列表按照下面的规律交叉合并
A = [10, 20, 30, 40, 50]B = [100, 200, 300]结果:[10, 100, 20, 200, 30, 300, 40, 50]
print('n作业5') A = [10, 20, 30, 40, 50] B = [100, 200, 300] c = [] for x in range(len(A)): c.append(A[x]) y = len(B)-1 if x <= y: c.append(B[x]) print(c)
-
已知两个有序列表,将两个列表合并,合并后的新列表中元素仍然是递增列表
A = [10, 20, 30, 40, 50]B = [25, 44, 60]结果:[10, 20, 25, 30, 40, 45, 50, 60]
print('n作业6') A = [10, 20, 30, 40, 50] B = [25, 44, 60] C = A + B C.sort() print(C)
最后
以上就是灵巧蜗牛为你收集整理的day7 - 日志和作业day7 - 日志和作业二.相关函数(系统函数)三.列表相关方法四.列表推导式五.元组作业的全部内容,希望文章能够帮你解决day7 - 日志和作业day7 - 日志和作业二.相关函数(系统函数)三.列表相关方法四.列表推导式五.元组作业所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复