Python_day04
集合操作 - 字典的近亲
集合的两个功能:
集合可以实现去重的功能;
集合可以实现关系测试; 交集, 差集,并集, 是否子集, 是否没有交集........
集合前菜:
现在IPV4下用一个32位无符号整数来表示,一般用点分方式来显示,点将IP地址分成4个部分,每个部分为8位
表示成一个无符号整数(因此不需要用正号出现),如10.137.17.1,是我们非常熟悉的IP地址,一个IP地址串
没有空格出现(因为要表示成一个32数字)。
现在需要你用程序来判断IP是否合法。
- 输入描述:输入一个ip地址,
- 输出描述:返回判断的结果YES or NO
示例1,
- 输入: 10.138.15.1,
- 输出: YES
程序:
测试:
集合set的定义:
集合是不重复的数据结构;
# 如果花括号里面为空,则是字典类型;
# 定义集合的第一种方式;
# 工厂方法定义集合时, 括号里面是可迭代的对象, eg: 数值类型不可以;
# 定义集合的第二种方式;定义一个空的集合;
应用: 如何实现列表去重?
- 转换为集合数据类型; set(列表);
- 字典的fromkeys方法实现;
# 实现列表去重1:
# 实现列表去重2:
集合的特性
- 集合是无序的, 不重复的数据类型;
- 因此不支持索引,也不支持切片;也不支持重复;也不支持连接;
- 支持成员操作符;
- 支持for循环;
# 集合支持for循环,是可迭代的;
集合的增删改查
1>.增
2>.查- (关系测试操作)
3>.删
- s.remove删除集合指定元素, 如果不存在,则报错;
- s.discard删除集合指定元素, 如果不存在,do nothing;
- s.clear清空集合元素;
应用:
题目描述:
明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性,他先用计算机生成了N个1到1000之间的
随机整数(N≤1000), N是用户输入的,对其中重复的数字,只保留一个,把其余相同的数去掉,不同的数对应
着不同的学生的学号。然后再把这些数从小到大排序,按照排好的顺序去找同学做调查。请你协助明明完成“去
重”与“排序”的工作;
- 提示:
- 生成随机数
import random
random.randint(1,1000)
- 列表的去重
程序:
测试:
# sorted是内置方法, 用来排序;
测试:
总结:
- 可变数据类型: 列表, 字典, 集合;
- 不可变数据类型: 数值类型, 字符串, 元组;
- 可变数据类型实现某个功能, 直接改变可变的数据类型;
- 不可变数据类型实现某个功能,需要将结果赋值给另外一个变量;
是否实现for循环:
- 可迭代数据类型: str, list, tuple, dict, set;
- 不可迭代数据类型:数值类型;
是否支持索引,切片, 重复和连接特性:
- 有序的数据类型: str, list, tuple;
- 无序的数据类型: dict, set;
乐高积木之函数
函数的定义:
def 函数名():
函数体
return 返回值1,返回值2
函数的调用:
函数名()
- 实现打印返回值:print 函数名()
- 总结:
- 定义函数时,函数不执行;
- 调用函数时,函数才执行;
有参数的函数
1>.必选参数
2>.默认参数
3>.可变参数
4>.关键字参数
必选参数 > 默认参数 > 可变参数 > 关键字参数;
返回值
函数中如果没有return时, 默认返回None
返回多个值
函数的作用域
注意:global关键字必须要先声明, 再赋值
# 全局变量
高级特性
迭代:
- 是否可以for循环遍历的对象;
- isinstance判断是否可迭代;
列表生成式
- 生成列表的公式;
- 需求: 生成一个列表, 返回1-100中偶数的平方;
方法1:
方法2:
变异的列表生成式
1>.for循环嵌套if语句
2>.for循环嵌套for循环, 两个字符串的全排列
练习:找出/etc下文件中以.conf结尾的文件;
提示:
- os.listdir(\"/etc\")
- s.enswith(\".conf\")