day7 - 日志和作业

作用
in 里面
not in 不在里面
sum(列表) 求和
max(列表) 求最大值
min(列表) 求最小值
sorted(列表) 从小到大排序
reverse = True 从大到小排序
list(数据) 转换成列表
列表.clear() 清空列表
列表.copy() 复制列表
列表.count() 统计元素个数
列表.extend(序列) 将序列中的所有元素添加到列表中
列表.index(元素) 获取元素在列表中对应下标
列表.reverse() 倒叙
sort 排序

一. 列表相关操作

  1. 数学运算符:+ 、*

    • 列表1+列表2

      将两个列表合并成一个新的列表

    • 列表 * N、 N * 列表

    ​ 将列表中的元素重复N产生一个新的列表

  2. 比较运算符:< , > , <= ,>= ,== ,!=

    • 比较相等:==,!=
    • 比较大小:>,<,<=,>=
      • 两个列表比较大小,比较的是第一对不相等的元素大小
  3. in 和not in

    • 元素 in 列表 - 判断指定列表中是否存在指定元素
    • 元素 not in 列表 - 判断指定列表中是否不存在指定元素

二.相关函数(系统函数)

  1. sum(列表)

    • 求列表中所有元素的和(列表必须是数字列表)
  2. max(列表)/min(列表)

    • 求列表中所有元素中的最大值/最小值
  3. sorted(列表)

    • 将列表中的元素从小打到大排序,产生一个新的列表
    • sorted(列表,reverse = True):将列表中的元素从大到小排序,产生一个新的列表
  4. list - 将其他数据装换成列表

    • list(数据) - 将指定数据转换成列表(所有的序列都可以转换成列表:将其他序列转换成列表的时候直接将序列的元素作为列表的元素)

三.列表相关方法

  1. clear

    • 列表.clear() - 清空列表
  2. copy

    • 列表.copy() - 复制指定列表产生一个一样的新列表,将新的列表返回
    • 原理:直接用一个变量给另外一个变量赋值,赋的地址,赋值后会导致两个变量同时指向同一块内存区域
    • 列表[:],列表*1,列表+[]的功能和列表.copy()的功能一样
  3. count

    • 列表.count(元素) - 统计列表中指定元素的个数
  4. extend

    • 列表.extend(序列) - 将序列中所有的元素都添加到列表中
  5. index

    • 列表.index(元素) - 获取元素在列表中对应下标(返回是0开始的那个下标)
    • 如果元素有多个,只返回最前面那个元素的下标
  6. reverse

    • 列表.reverse() - 倒叙
  7. sort

    • 列表.sort() -将列表元素从小到大排序
    • 列表.sort(reverse=True) - 将列表元素从大到小排序
    • sorted(列表) - 将列表元素从小到大排序,产生一个新的列表
    • sorted(列表,reverse=True) - 将列表元素从小到大排序,产生一个新的列表

四.列表推导式

  1. 列表推导式 - 创建列表的表达式,主要用于对元素进行变换和筛选

    • 结构1:[表达式 for 变量 in 序列]

      原理:创建一个列表(让变量去序列中取值,一个一个的取,取一个值就计算一次表达式的结果并且将计算结果放入列表)

      作用:将原序列中的元素按照指定规则(表达式)进行统一变换得到一个列表

    • 结构2:[表达式 for 变量 in 序列 if 条件语句]

      原理:将变量去序列中取值,一个一个的取,去一个值就判断一次条件语句是否成立,如果成立才计算表达式的结果,并且将结果作为序列的结果

五.元组

  1. 认识元组(tuple)

    • 是容器;将()作为容器的标志里面多个元素用逗号隔开:(元素1,元素2,元素3,…)

    • 不可变的(不支持增删改)

    • 有序的

    • 单个元素的元组:必须在唯一的元素后加逗号

  2. 元组就是不可变的列表

    • 列表中和增删改无关的操作,元组都支持

      • 切片
      • len()获取元组元素数量
      • 遍历
      • 加法,乘法,比较,in,not in
    • 相关函数:sum,max,min,len,sorted
    • 部分相关方法:count、index
  3. 元组不只是不可变的列表

    • 单个元素的元组:(元素,)
    • 在没有歧义的情况下,元组的()可以省略
    • 获取元素的时候,可以让变量的个数和元组中元素一致

作业

  1. 创建一个列表,列表中有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))
  1. 利用列表推导式, 完成以下需求

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)
  1. 已知一个列表获取列表中指定元素所有的下标

    例如:[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)
    
  2. *已知一个数字列表,写程序判断这个列表时候是连续递增列表。

    例如:
    [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)
    
  3. 已知两个列表,将两个列表按照下面的规律交叉合并

    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)-1if x <= y:c.append(B[x])
    print(c)
    
  4. 已知两个有序列表,将两个列表合并,合并后的新列表中元素仍然是递增列表

    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 - 日志和作业相关推荐

  1. [教学管理] 学生作业及日志查收的纯MySQL解决方案

    DROP TABLE IF EXISTS `章节表`; CREATE TABLE `章节表` (`章节ID` int(11) NOT NULL AUTO_INCREMENT,`章节名称` varcha ...

  2. 《团队作业》五小福团队--UNO的博客链接汇总

    <团队作业>五小福团队--UNO的博客链接汇总 <团队作业第一周>五小福团队作业--UNO <团队作业第二周>五小福团队作业--UNO <团队作业第三.第四周 ...

  3. 自带的jvm监控不准_如何实时监控 Flink 集群和作业?

    Flink 相关的组件和作业的稳定性通常是比较关键的,所以得需要对它们进行监控,如果有异常,则需要及时告警通知.本章先会教会教会大家如何利用现有 Flink UI 上面的信息去发现和排查问题,会指明一 ...

  4. 了解SQL Server事务日志备份和完整备份的日志序列号

    This article explores the SQL Server Transaction log backups and log sequence number (LSN) in combin ...

  5. ssms 和sql_使用T-SQL和SSMS监视事务日志传送

    ssms 和sql Database Administrators are vigilant on the backup and restore processes and use the Monit ...

  6. 使用SQL Server日志传送将SQL数据库移动到其他服务器

    As a SQL Server DBA, we are responsible for moving the customer SQL databases to other servers. Rece ...

  7. 数据库镜像怎么还原数据库_镜像数据库上的日志传送

    数据库镜像怎么还原数据库 Both log shipping and mirroring are high availability and disaster recovery options ava ...

  8. 使用SQL Server Management Studio 创建数据库备份作业

    --完整备份,每周一次 USE Master GO declare @str varchar(100) set @str='D:\Weldon\DBBACK\FullBak'+replace(repl ...

  9. sqlserver 2012实施与管理学习笔记(一):选型和部署之单机部署、故障转移群集与日志传送

    sqlserver 2012实施与管理学习笔记(一):选型和部署之单机部署.故障转移群集与日志传送 数据库的选型和部署 sqlserver的安装和升级 选择高可用性和灾难恢复技术 故障转移群集 日志传 ...

最新文章

  1. SQL,NoSQL优缺点总结
  2. Angular--TypeScript finalize 方法
  3. 消费升级背景下零食行业发展报告_趋势丨零食行业进入4.0时代
  4. 充分感受中国缺少管理型软件人才的说法
  5. 直男们给我看清楚!这才是小姐姐的真面目......
  6. php scandir sftp,CentOS 下使用SFTP实现网站自动生成FTP账号,实现Chroot功能
  7. 锦江公司 nginx 转发
  8. 深度学习的应用:语音识别、图像理解、自然语言处理
  9. 使用Nexus搭建Maven仓库
  10. 拓端tecdat|R语言中的风险价值模型度量指标TVaR与VaR
  11. 爬虫伪装请求头-fake-useragent
  12. 商城项目数据库设计中订单表
  13. 数学连乘和累加运算符号_数学所有的公式和符号
  14. FFmpeg 软编码h.264与H.265(从简到深)
  15. 如何计算 R 中 T 检验 的 P 值
  16. 给Jetson Nano更换eMMC闪存(扩容)
  17. Flume错误:Flume:Class path contains multiple SLF4J bindings
  18. selenium——爬取qq空间说说
  19. Ubuntu18.04 配置nvidia 460驱动、cuda10.1和cudnn7.6.5
  20. 如何用英文说明一种方法的优缺点(优点和缺点)

热门文章

  1. LS1046A SGMII网口无PHY芯片的配置
  2. 《数据分析-Echarts》Python + Django + echarts图表展示
  3. 于浩java_巅峰之战 三款最热java浏览器横评
  4. Photoshop关于中性灰的正确性论述
  5. springboot-jpa扫描包
  6. 如何做一碗完美的葱油拌面?
  7. AnnotationAwareAspectJAutoProxyCreator is only available on Java 1.5 and higher
  8. java调用ecdh_java – BouncyCastle ECDH密钥协议失败
  9. Leetcode——565. Array Nesting
  10. uevent 驱动_uevent机制