Python入门一

news2025/1/15 15:24:48

目录:

  1. python基本操作
  2. python基本数据类型
  3. python字符串基本操作
  4. python的运算符
  5. python控制流-判断
  6. python控制流-循环
  7. python常用数据结构-列表
  8. python常用数据结构-元组
  9. python常用数据结构-集合
  10. python常用数据结构-字典
  11. python函数
  12. python函数进阶与参数处理
  13. pythonlambda表达式
  14. python面向对象概念
  15. python类与对象
  16. 学生信息管理系统

1.python基本操作

基本操作注意事项 

  • 缩进与空格
  • 编写规范
    • 注释
    • 符合规范性,命名要见名知意
    • 不要用关键字命名

PEP8 编码规范

  • 收藏了解
  • https://www.python.org/dev/peps/pep-0008/

2.python基本数据类型

变量:

  • 变量是一种存储数据的载体,计算机中的变量是实际存在的数据或者说是存储器中存储数据的一块内存空间
  • 变量的值可以被读取和修改

变量命名规则:

  • 变量名由字母(广义的 Unicode 字符,不包括特殊字符)、数字和下划线构成,数字不能开头
  • 大小写敏感(大写的A和小写的a是两个不同的变量)
  • 不要跟关键字(有特殊含义的单词)和系统保留字(如函数、模块等名字)冲突

数字:

  • int
    • 整形,没有小数点的,包括 1,100,0,-1,-100
  • float
    • 浮点型,带有小数点,包括 1.0,-1.0,-1.1
int_a = 1
print(int_a)
print(type(int_a))

float_a = 1.0
print(float_a)
print(type(float_a))

布尔:

  • True
  • False
bool_a = True
print(bool_a)
print(type(bool_a))

bool_b = False
print(bool_b)
print(type(bool_b))

 字符串:

  • \ 转义符
  • r 忽略转义符的作业
  • + 多个字符串连接
  • 索引
  • 切片
# `\` 转义符
str_a = "adb\\n123456"
print(str_a)
# `r` 忽略转义符的作业
str_b = r"adb\n123456"
print(str_b)
# `+` 多个字符串连接
str_c = str_a + str_b
print(str_c)

字符串(索引+切片):

字符串:“abcdefg”

索引:    0123456

切片: start: stop: step

str_d = "abcdefg"
print(str_d[0])
# x>=1
print(str_d[1:])
# 前闭后开原则,1<=x<5
print(str_d[1:5])
# 步长,
print(str_d[1:5:2])
print(str_d[1::2])

列表(List):

var_list = [1, 2, 3, 4, 5, "a", "b", "c", True]
print(var_list)
print(var_list[0])
print(var_list[-1])
print(var_list[2:-2])
print(var_list[2::2])

3.python字符串基本操作

字符串操作的使用场景:

  • 数据提取之后的通用格式
    • 日志
    • excel
  • 第三方数据信息

字符串的定义:

# 单行
str_a = "this is a str"
print(str_a)

# 多行
str_b = """
这是一段字符串
hello workld
"""
print(str_b)

 字符串常用特殊字符:

# 换行
print("hello \n world")
# 转义
print("hello \\n world")

字符串格式化符号:

符号描述
%c格式化字符及其ASCII码
%s格式化字符串
%d格式化整数
%u格式化无符号整型
%o格式化无符号八进制数
%x格式化无符号十六进制数
%X格式化无符号十六进制数(大写)
%f格式化浮点数字,可指定小数点后的精度
%e用科学计数法格式化浮点数
%p用十六进制数格式化变量的地址
# world替换掉 %s 的位置
print("hello %s" % "world")

 字符串之字面量插值:

  • “str”.format()
# 不设置指定位置,按默认顺序
print("{} {}".format("hello", "world"))
# 设置指定位置
print("{1} {0}".format("hello", "world"))
# 通过名称传递变量
print("{name}hello".format(name="world"))

 字符串之字面量插值:

  • f”{变量}”
name = "Bob"
school = "hdc"
# 通过 f"{变量名}"
print(f"我的名字叫做{name}, 毕业于{school}")

 字符串常用API之join:

  • join
    • 列表转换为字符串
a = ["h", "e", "l", "l", "o"]
# 将列表中的每一个元素拼接起来
print("".join(a))
print("|".join(a))

 字符串常用API之split:

  • split
    • 数据切分操作
# 根据split内的内容将字符串进行切分
b="hello world"
print(b.split(" "))

字符串常用API之replace:

  • replace
    • 将目标的字符串替换为想要的字符串
# 将原字符串中的 world 替换为 tom
print("hello world".replace("world", "tom"))

字符串常用API之strip:

  • strip
    • 去掉首尾的空格
print(" hello world ".strip())

4.python的运算符

运算符的作用

  • Python 基础语法的内容
  • 通常表示不同数据或变量之间的关系

算数运算符:

+
-
*
/
%取模
**
//取整除

# 加
a = 1 + 1
print(a)

# 减
b = 2 - 1
print(b)

# 变量之间也可以做运算
c = 4
d = 3
e = c - d
print(e)

# 乘
f = 1 * 2
print(f)

# 除
g = 3 / 2
print(g)

# 取模(取余)
h = 5 % 2
print(h)

# 幂
i = 2 ** 3
print(i)

# 取整除
j = 3 // 2
print(j)

比较运算符:

==等于
!=不等于
>大于
<小于
>=大于等于
<=小于等于

a = 1
b = 2
print(a == b)
print(a != b)
print(a > b)
print(a < b)
print(a <= b)
print(a >= b)

 赋值运算符:

=简单赋值运算符
+=加法赋值运算符
-=减法赋值运算符
*=乘法赋值运算符
/=除法赋值运算符
%=取模赋值运算符
**=幂赋值运算符
//=取整赋值运算符

# 简单赋值
a = 1
print(a)
# 多个变量赋值
a, b = 1, 2
print(a)
print(b)
# 加法运算
a = a + 1
print(a)
# 加法赋值运算
a += 1
print(a)

逻辑运算符:

运算符逻辑表达式描述
andx and yx、y 都为真才为真,有一个为假即为假
orx or yx、y 有一个为真即为真,都为假为假
notnot x如果 x 为假,则 not x 为真

a, b = True, False
print(a and b)
print(a or b)
print(not a)
print(not b)

 成员运算符:

运算符描述
in如果在指定的序列中找到值返回 True,否则返回 False。
not in如果在指定的序列中没有找到值返回 True,否则返回 False。

list_a = ["a", "b", "c"]
str_a = "abcde"
str_b = "bcde"

print("a" in list_a)
print("a" not in list_a)
print("a" in str_a)
print("a" not in str_a)
print("a" in str_b)

身份运算符:

运算符描述
isis 是判断两个标识符是不是引用自一个对象
is notis not 是判断两个标识符是不是引用自不同对象

list_a = ["a", "b", "c"]
list_b = ["a", "b", "c"]

# 使用id查看变量的内存地址
print(id(list_a))
print(id(list_b))
print(list_a is list_b)
print(list_a == list_b)

5.python控制流-判断

什么是分支判断?

  • 一条一条语句顺序执行叫做顺序结构
  • 分支结构就是在某个判断条件后,选择一条分支去执行

PlantUML diagram

 if 条件判断:

bob = "teacher"
if bob == "teacher":
    print("老师")

 else 判断语句:

bob = "student"
if bob == "teacher":
    print("老师")
else:
    print("student")

elif 多重条件:

food = "apple"
if food == "apple":
    print("苹果")
elif food == "orange":
    print("橘子")
elif food == "banana":
    print("香蕉")
else:
    print("fruit")

 分支嵌套:

my_list = [1, 2, 3, 4, 5]

if my_list:
    print("my_list 不为空")
    if my_list[0] == 3:
        print("my_list 中的第一个元素为 3")
    else:
        print("my_list 中的第一个元素不是 3")
else:
    print("my_list 为空")

三目运算符:

# 正常的赋值操作和判断语句结合
a, b = 1, 2
if a > b:
    h = "变量1"
else:
    h = "变量2"
# 优化之后更简洁的写法
a, b = 1, 2;
h = "变量1" if a > b else "变量2"
print(h)

6.python控制流-循环

什么是循环:

  • 循环语句允许我们执行一个语句或语句组多次
  • python提供了for循环和while循环

循环的作用:

  • 封装重复操作
  • Python最重要的基础语法之一

for-in循环:

  • 使用场景:
    • 明确的知道循环执行的次数或者要对一个容器进行迭代
  • range 函数
    • range(101)可以产生一个0到100的整数序列。
    • range(1, 100)可以产生一个1到99的整数序列。
    • range(1, 100, 2)可以产生一个1到99的奇数序列,其中的2是步长。
# 使用for 循环遍历列表中的元素
for i in [1, 2, 3]:
    print(i)

# for 循环结合 range函数
for i in range(1, 100, 2):
    print(i)

while 循环:

  • 满足条件,进入循环
  • 需要设定好循环结束条件
count = 0
# while循环条件,满足条件执行循环体内代码
while count < 5:
    # count 变量+1,否则会进入死循环
    print(count)
    count += 1

continue:跳出当前轮次循环:

count = 0

while count < 5:
    print(count)
    if count == 3:
        count += 1.5
        continue
    count += 1


list_demo = [1, 2, 3, 4, 5, 6]
# 循环遍历列表
for i in list_demo:
    # 如果i 等于3,那么跳出当前这轮循环,不会再打印3
    if i == 3:
        continue
    print(i)

pass:

  • 没有实质性含义,通常占位使用
  • 不影响代码的执行逻辑
print("hdc")
pass
print("school")

 练习:

  • 计算1~100 求和
    • 使用分支结构实现1~100之间的偶数求和
    • 不使用分支结构实现1~100之间的偶数求和
    • 不使用分支结构实现1~100之间的奇数求和
    • 使用while语句实现1~100之间的奇数求和
# 使用分支结构实现1~100之间的偶数求和
sum = 0
for i in range(1, 101):
    if i % 2 == 0:
        sum += i
print(sum)
# 不使用分支结构实现1~100之间的偶数求和
sum = 0
for i in range(0, 101, 2):
    sum += i
print(sum)
# 不使用分支结构实现1~100之间的奇数求和
sum = 0
for i in range(1, 101, 2):
    sum += i
print(sum)
# 使用while语句实现1~100之间的奇数求和
i, sum = 1, 0
while i < 101:
    if i % 2 == 1:
        sum += i
    i += 1
print(sum)
  • 猜数字游戏
    • 计算机出一个1~100之间的随机数由人来猜
    • 计算机根据人猜的数字分别
    • 给出提示大一点/小一点/猜对了
import random

# 生成随机数
number = random.randint(1, 100)

# 初始化猜测次数和最大猜测次数
guesses = 0
max_guesses = 10

# 提示用户开始猜测
print("我在想一个介于1到100之间的数字。你能猜出它是什么吗?")

# 循环猜测,直到用户猜对或猜测次数用尽
while guesses < max_guesses:
    # 提示用户输入猜测的数字
    guess = int(input("输入你的猜测: "))
    guesses += 1

    # 判断猜测是否正确
    if guess == number:
        print("恭喜你!你猜对了号码一共猜了", guesses, "次.")
        break
    elif guess < number:
        print("你猜测的数字太小了.")
    else:
        print("你猜测的数字太大了.")

7.python常用数据结构-列表

列表定义:

  • 列表是有序的可变元素的集合,使用中括号[]包围,元素之间用逗号分隔

  • 列表是动态的,可以随时扩展和收缩

  • 列表是异构的,可以同时存放不同类型的对象

  • 列表中允许出现重复元素

列表使用:创建:

# 1、通过构造函数创建
li1 = list()  # 空列表
li2 = list('hello')  # 字符串
li3 = list((1, 2, 3))  # 元组
li4 = list({4, 5, 6})  # 集合
li5 = list({'a': 7, 'b': 8})  # 字典
print(type(li1), li1)
print(type(li2), li2)
print(type(li3), li3)
print(type(li4), li4)
print(type(li5), li5)

# 2、中括号创建并填充元素
li6 = []  # 空列表
li7 = [1, 2, 3]  # 直接填充对象
print(type(li6), li6)
print(type(li7), li7)

 列表使用:索引

li = [1, 2, 3, 4, 5]

# 1、正向索引
print(li[0])  # 打印1
print(li[3])  # 打印4

# 2、反向索引
li = [1, 2, 3, 4, 5]
print(li[-1])  # 打印 5

列表使用:切片

  • 切片 [start: stop: step]

    • start 值: 指示开始索引值,如果没有指定,则默认开始值为 0;
    • stop 值: 指示到哪个索引值结束,但不包括这个结束索引值。如果没有指定,则取列表允许的最大索引值;
    • step 值: 步长值指示每一步大小,如果没有指定,则默认步长值为 1。
    • 三个值都是可选的,非必填
# 切片基本用法
li = ['h', 'e', 'l', 'l', 'o', 'w', 'o', 'r', 'l', 'd']
print(li[0:5:2])
print(li[2:4])
print(li[:4])
print(li[2:])
print(li[::2])
print(li[::-1])

 列表使用:运算符:

  • 重复
    • 使用 * 运算符可以重复生成列表元素。
  • 合并
    • 使用 + 加号运算符,可以将两个列表合二为一。
# 1、重复
li = [1] * 5
print(li)  # 打印[1, 1, 1, 1, 1]

# 2、合并
li1 = [1, 2, 3]
li2 = [99, 100]
print(li1 + li2)  # 打印[1, 2, 3, 99, 100]

 列表使用:成员检测:

  • in:检查一个对象是否在列表中,如果在则返回 True,否则返回 False。

  • not in:检查一个列表是否不包含某个元素。如果不在返回 True,否则返回 False。

li = [1, 2, 3]

# in
print(1 in li)  # 返回True
print(100 in li)  # 返回False

# not in
print(1 not in li)  # 返回False
print(100 not in li)  # 返回True

列表方法

  • append()
  • extend()
  • insert()
  • pop()
  • remove()
  • sort()
  • reverse()

列表方法 append():

  • append(item):将一个对象 item 添加到列表的末尾。

  • 入参:对象 item

  • 返回:None

# 添加元素
li = []
li.append(1)
li.append(3.14)
li.append("hello world")
li.append([6, 6, 6])
li.append((1.2, 1.5))
li.append({'msg': "Hello"})

print(li)  # 打印列表
print(len(li))  # 获取列表元素个数

 列表方法 extend()

  • extend(iterable):将一个可迭代对象的所有元素,添加到列表末尾。
  • 入参:可迭代对象 iterable
  • 返回:None
# extend()的用法
li = []
li.extend('helloworld')  # 添加的是字符串的所有字母
li.extend([1, 2, 3])  # 接收列表的所有元素
li.extend((4, 5, 6))  # 接收元组的所有元素
li.extend({'a': 1, 'b': 2})  # 接收字典的所有key值
print(li)

列表方法 insert()

  • insert(index, item):将一个对象插入到指定的索引位置

  • 入参:索引值 index ,一个对象 item

  • 返回:None

  • 原索引位置及后面的元素后移一位

li = [0, 1, 2]
print("插入前: ", li)  # 打印 [0, 1, 2]

# 在索引0的位置插入元素
li.insert(0, 'hello world')
print("插入后: ", li)  # 打印 ['hello world', 0, 1, 2]

列表方法 pop()

  • pop(index) 或 pop()

  • 弹出并返回所指定索引的元素。

  • 入参:索引值 index,可不传

  • 返回:指定索引的元素

  • 返回:未指定索引则返回末尾元素

  • 如果索引值不正确,或者列表已经为空,则引发 IndexError 错误

letters = ['h', 'e', 'l', 'l', 'o', 'w', 'o', 'r', 'l', 'd']
print(letters)

n1 = letters.pop(3)
print(n1)
print(letters)

# 不传参数,默认弹出末尾元素
n2 = letters.pop()
print(n2)
print(letters)

 列表方法 remove()

  • remove(item)

  • 移除列表中第一个等于 item 的元素

  • 入参:指定元素 item

  • 返回:None

  • 目标元素必须已存在,否则会报 ValueError

li = ['h', 'e', 'l', 'l', 'o', 'w', 'o', 'r', 'l', 'd']
print(len(li))

# 1、删除指定元素'h'
li.remove('h')
print(li)
print(len(li))

# 2、移除第一个2
li = [1, 2, 3, 2, 1]
li.remove(2)
print(li)  # 打印 [1, 3, 2, 1]

# 3、删除不存在的元素,会报ValueError错误
li = [1, 2, 3]
li.remove(100)

 列表方法 sort()

  • sort(key=None, reverse=False)

  • 对列表进行原地排序,只使用 < 来进行各项间比较。

  • 入参:支持 2 个关键字参数:

    • key:指定带有一个参数的函数,用于从每个列表元素中提取比较键。
    • reverse:默认值为 False 表示升序,为 True 表示降序
  • 返回:None

nums = [2, 4, 3, 1, 5]

# 1、不传参数,默认升序,数字从小到大排列
nums.sort()
print(nums)  # 打印 [1, 2, 3, 4, 5]

# 2、指定key=len,按元素的长度排序
words = ['Python', 'Java', 'R', 'Go']
words.sort(key=len,reverse=False)
print(words)
words.sort(key=len,reverse=True)
print(words) 

# 3、指定reverse=True,降序
nums = [2, 4, 3, 1, 5]
nums.sort(reverse=True)
print(nums)  # 打印 [5, 4, 3, 2, 1]

 列表方法 reverse()

  • reverse():将列表中的元素顺序反转
  • 参数:无
  • 返回:None
  • 反转只是针对索引值,元素之间不相互比较。
# 反转顺序
nums = [8, 1, 5, 2, 77]
nums.reverse()
print(nums)  # 打印[77, 2, 5, 1, 8]

 列表嵌套

  • 嵌套列表是指在列表里存放列表
  • 列表的常用方法都适用于嵌套列表
# 1、创建嵌套列表
li_2d = [['a', 'b', 'c'], [1, 2, 3]]
print(type(li_2d))  # 打印<class 'list'>
print(len(li_2d))  # 打印 2

# 2、访问嵌套列表中的元素
print(li_2d[0][2])  # 打印 'c'
print(li_2d[1][0])

列表推导式: 

  • 列表推导式是指循环创建列表,相当于for循环创建列表的简化版
  • 语法∶[x for x in li if x...]
# 实例:将1-10中的所有偶数平方后组成新的列表
# 1、传统解决方案
result = []
for ele in range(1, 11):
    if ele % 2 == 0:
        result.append(ele ** 2)
print(result)

# 2、使用列表推导式
result = [ele ** 2 for ele in range(1, 11) if ele % 2 == 0]
print(result)

8.python常用数据结构-元组

元组定义:

  • 元组是有序的不可变对象集合
  • 元组使用小括号包围,各个对象之间使用逗号分隔
  • 元组是异构的,可以包含多种数据类型

元组使用:创建:

  • 创建
    • 使用逗号分隔
    • 通过小括号填充元素
    • 通过构造方法 tuple(iterable)
# 1、直接使用逗号分隔
t5 = 1, 2, 3
print(type(t5))

# 2、通过小括号填充元素
t3 = (1, 2, 3)
print(t3)
print(type(t3))

t4 = ('a', 'b', 'c')
print(t4)
print(type(t4))

# 3、通过构造函数tuple()
t1 = tuple()
print(type(t1))

t2 = tuple([1, 2, 3])
print(t2)
print(type(t2))

元组使用:索引

  • 索引

  • 可以通过索引值来访问对应的元素。

    • 正向索引,默认编号从 0 开始
    • 反向索引,默认编号从-1 开始
t = tuple(range(1, 6))
print(t)

# 正向索引
print(t[2])

# 反向索引
print(t[-1])

元组使用:切片

  • 切片 [start: stop: step]

    • 三个值都是可选的,非必填
    • start 值: 指示开始索引值,如果没有指定,则默认开始值为 0;
    • stop 值:指示到哪个索引值结束,但不包括这个结束索引值。如果没有指定,则取元组允许的最大索引值;
    • step 值:步长值指示每一步大小,如果没有指定,则默认步长值为 1。
# 切片的使用
t = (1, 2, 3, 4, 5, 6)

print(t[:])
print(t[:-2])
print(t[2:4])
print(t[2:5:2])

# 特殊的切片写法:逆序
print(t[::-1])

元组常用方法

  • index()
  • count()

元组常用方法 index()

  • index(item)

  • 返回与目标元素相匹配的首个元素的索引。

  • 目标必须在元组中存在的,否则会报错

t = (1, 3, 2, 3, 2)
print(t.index(3))

t = ('h', 'e', 'l', 'l', 'o', 'r', 'w', 'o', 'r', 'l', 'd')
print(t.index('h'))

元组常用方法 count()

  • count(item):返回某个元素出现的次数。

  • 入参:对象 item

  • 返回:次数

t = (1, 2, 2, 3, 3, 3, 3)
print(t.count(3))

t = ('h', 'e', 'l', 'l', 'o', 'r', 'w', 'o', 'r', 'l', 'd')
print(t.count('h'))

元组解包

  • 元组解包:把一个可迭代对象里的元素,一并赋值到由对应的变量组成的元组中。
# 传统逐个赋值的方式
t = (1, 2, 3)
a = t[0]
b = t[1]
c = t[2]
print(a, b, c)

# 使用元组解包,一气呵成
a, b, c = (1, 2, 3)
print(a, b, c)

元组与列表对比

  • 相同点
    • 都是有序的
    • 都是异构的,能够包含不同类型的对象
    • 都支持索引和切片
  • 区别
    • 声明方式不同,元组使用(),列表使用 []
    • 列表是可变的,元组是不可变的

9.python常用数据结构-集合

集合定义

  • 无序的唯一对象集合
  • 用大括号{}包围,对象相互之间使用逗号分隔
  • 集合是动态的,可以随时添加或删除元素
  • 集合是异构的,可以包含不同类型的数据

集合使用:创建

  • 创建
    • 通过使用{}填充元素
    • 通过构造方法 set()
    • 通过集合推导式
"""创建集合"""
# 1、使用大括号{}填充元素
st4 = {1, 2, 3}
st5 = {'a', 'b', 'c'}

# 2、使用构造方法创建集合
st1 = set()  # 空集合
st2 = set('hello world')

li = [1, 1, 2, 2, 3, 3]
st3 = set(li)
print(st3)
print(type(st3))

# 3、使用集合推导式
st6 = {x for x in li}
print(st6)
# 注意:不要单独使用{ }来创建空集合
st7 = {}  # 这是字典类型
print(type(st7))

 集合使用:成员检测:

  • in
    • 判断元素是否在集合中存在
  • not in
    • 判断元素是否在集合中不存在
"""集合使用:成员检测"""
st = {1, 2, 3, 4, 5}
# in
print(2 in st)

# not in
print(99 not in st)

集合方法

  • add()
  • update()
  • remove()
  • discard()
  • pop()
  • clear()

 集合方法 add()

  • add(item):将单个对象添加到集合中
  • 入参:对象 item
  • 返回:None
"""集合方法 add()"""
# 添加元素
st = {1, 2, 3}
st.add(99)
st.add('hello')
print(st)
print(type(st))

 集合方法 update()

  • update(iterable)

  • 批量添加来自可迭代对象中的所有元素

  • 入参:可迭代对象 iterable

  • 返回:None

"""集合方法 update()"""
li = [1, 2, 3]
tup = (2, 3, 4)
st = {'a', 'b', 'c'}

# 1、批量添加列表中的元素
st1 = set()
st1.update(li)
print(st1)
# 2、批量添加元组中的元素
st1.update(tup)
print(st1)
# 3、批量添加集合中的元素
st1.update(st)
print(st1)

集合方法 remove()

  • remove(item):从集合中移除指定元素 item。
  • 入参:指定元素值
  • 返回:None
  • 如果 item 不存在于集合中则会引发 KeyError
"""集合方法 remove()"""
# 1、删除已存在的元素
st = {1, 2, 3, 4, 5}
print(st)
st.remove(2)
print(st)

# 2、删除不存在的元素
st.remove(1024)  # KeyError

 集合方法 discard()

  • discard(item):从集合中移除指定对象 item。
  • 入参:指定对象值
  • 返回:None
  • 元素 item 不存在没影响,不会抛出 KeyError 错误。
"""集合方法 discard()"""
# 1、删除已存在的元素
st = {1, 2, 3, 4, 5}
print(st)
st.remove(2)
print(st)

# 2、删除不存在的元素
st.discard(1024)
print(st)

集合方法 pop()

  • pop():随机从集合中移除并返回一个元素。
  • 入参:无。
  • 返回:被移除的元组。
  • 如果集合为空则会引发 KeyError。
"""集合方法 pop()"""
# 1、随机删除某个对象
st = {1, 2, 3, 4, 5}
print(st)
item = st.pop()
print(item, st)

# 2、集合本身为空会报错
st = set()
st.pop()  # KeyError

集合方法 clear()

  • clear():清空集合,移除所有元素
  • 入参:无
  • 返回:None
"""集合方法 clear()"""
# 1、清空集合
st = {1, 2, 3, 4, 5}
print(st)
st.clear()
print(st)

集合运算

  • 交集运算
  • 并集运算
  • 差集运算

 集合运算:交集

  • 交集运算

  • intersection()

  • 操作符:&

"""集合运算:交集"""
# 交集运算
set1 = {1, 3, 2}
set2 = {2, 4, 3}
print(set1.intersection(set2))
print(set1 & set2)

 集合运算:并集

  • 并集运算

  • union()

  • 操作符:|

"""集合运算:并集"""
# 求两个集合的并集
set1 = {1, 3, 2}
set2 = {2, 4, 3}
print(set1.union(set2))
print(set1 | set2)

集合运算:差集

  • 差集运算

  • difference()

  • 操作符: -

"""集合运算:差集"""
# 集合求差集
set1 = {1, 3, 2}
set2 = {2, 4, 3}

print(set1.difference(set2))
print(set1 - set2)

集合推导式

  • 类似列表推导式,同样集合支持集合推导式
  • 语法:{x for x in ... if ...}
st = set()
for s in "hold":
    if s in "hello world":
        st.add(s)
print(st)
print(type(st))

# 使用推导式生成集合
"""集合推导式"""
# 使用推导式生成集合
# 实例:寻找 hold 与 hello world的共相同字母
st = {x for x in 'hold' if x in 'hello world'}
print(st)
print(type(st))

10.python常用数据结构-字典

字典定义

  • 字典是无序的键值对集合
  • 字典用大括号{}包围
  • 每个键/值对之间用一个逗号分隔
  • 各个键与值之间用一个冒号分隔
  • 字典是动态的

字典使用:创建

  • 创建字典
    • 使用大括号填充键值对
    • 通过构造方法 dict()
    • 使用字典推导式
"""字典使用:创建"""
# 1、使用大括号填充键值对
dc = {'name': 'Harry Potter', 'age': 18}
print(type(dc), dc)

# 2、使用字典构造方法
dc1 = dict()  # 空字典
dc2 = dict(name="Harry Potter", age=18)  # 关键字参数赋值
print(type(dc2), dc2)

dc3 = dict([("name", "Harry Potter"), ("age", 18)])
print(type(dc3), dc3)

# 3、使用字典推导式
dc4 = {k: v for k, v in [("name", "Harry Potter"), ("age", 18)]}
print(type(dc4), dc4)

 字典使用:访问元素

  • 访问元素
    • 与字典也支持中括号记法[key]
    • 字典使用键来访问其关联的值。
    • 访问时对应的 key 必须要存在
"""字典使用:访问元素"""
dc = {"name": "Harry Potter", "age": 18}
# 1、访问存在的key
print(dc["name"])
print(dc["age"])

# 2、访问不存在的key,会报KeyError错误
print(dc['hobby'])

字典使用:操作元素

  • 语法:dict[key] = value
  • 添加元素
    • 键不存在
  • 修改元素
    • 键已经存在
"""字典使用:操作元素"""
dc = {"name": "Harry Potter", "age": 18}
# 1、修改年龄,改为20
dc['age'] = 20
print(dc)

# 2、新增hobby字段
dc['hobby'] = 'Magic'
print(dc)

字典使用:嵌套字典

  • 嵌套字典

  • 字典的值可以是字典对象

"""字典使用:嵌套字典"""
dc = {"name": "Harry Potter", "age": 18, "course": {"magic": 90, "python": 80}}
# 1、获取课程Magic的值
print(dc['course']['magic'])

# 2、把python分数改成100分
dc['course']['python'] = 100
print(dc)

 字典方法

  • keys()
  • values()
  • items()
  • get()
  • update()
  • pop()

 字典方法 keys()

  • keys()

  • 返回由字典键组成的一个新视图对象。

  • 入参:无

"""字典方法 keys()"""
dc = {"name": "Harry Potter", "age": 18}
keys = dc.keys()
print(dc.keys())
print(dc.values())
print(dc.items())

# 1、遍历查看所有的键
for key in keys:
    print(key)

# 2、将视图对象转成列表
print(list(keys))
print(list(dc.values()))

字典方法 values()

  • values()

  • 返回由字典值组成的一个新视图对象。

"""字典方法 values()"""
dc = {"name": "Harry Potter", "age": 18}
values = dc.values()
print(type(values), values)

# 1、遍历查看所有的值
for value in values:
    print(value)

# 2、将视图对象转成列表
print(list(values))

 字典方法 items()

  • items()

  • 返回由字典项 ((键, 值) 对) 组成的一个新视图对象。

"""字典方法 items()"""
dc = {"name": "Harry Potter", "age": 18}
items = dc.items()
print(type(items), items)

# 1、遍历查看所有的项
for item in items:
    print(item)

# 2、将视图对象转成列表
print(list(items))

 字典方法 get()

  • get(key)

  • 获取指定 key 关联的 value 值。

  • 入参:

    • key:字典的键,必传。
  • 返回:

    • 如果 key 存在于字典中,返回 key 关联的 value 值。
    • 如果 key 不存在,则返回 None。
  • 此方法的好处是无需担心 key 是否存在,永远都不会引发 KeyError 错误。

"""字典方法 get()"""
dc = {"name": "Harry Potter", "age": 18}

# 1、访问存在的key
name = dc.get("name")
print(name)

# 2、访问不存在的key
hobby = dc.get('hobby')
print(hobby)

字典方法 update()

  • update(dict)

  • 使用来自 dict 的键/值对更新字典,覆盖原有的键和值。

  • 入参:

    • dc:字典对象,必传
  • 返回:None

dc = {"name": "Harry Potter", "age": 18}
dc.update({"age": 20, "hobby": "magic"})
print(dc)

字典方法 pop()

  • pop(key)

  • 删除指定 key 的键值对,并返回对应 value 值。

  • 入参:

    • key:必传
  • 返回:

    • 如果 key 存在于字典中,则将其移除并返回 value 值
    • 如果 key 不存在于字典中,则会引发 KeyError。
"""字典方法 pop()"""
dc = {"name": "Harry Potter", "age": 18}

# 1、弹出
item = dc.pop("age")
print(dc, item)

# 2、删除不存在的key
dc.pop("hobby")  # 报错keyError

字典推导式

  • 字典推导式:可以从任何以键值对作为元素的可迭代对象中构建出字典。

  • 实例:给定一个字典对象{'a': 1, 'b': 2, 'c': 3},找出其中所有大于 1 的键值对,同时 value 值进行平方运算。

# 未使用字典推导式的写法
dc = {'a': 1, 'b': 2, 'c': 3}
d_old = dict()
for k, v in dc.items():
    if v > 1:
        d_old[k] = v ** 2
print(d_old)

# 使用字典推导式
d_new = {k: v ** 2 for k, v in dc.items() if v > 1}
print(d_new)

练习:

# 给定一个字典对象,请使用字典推导式,将它的key和value分别进行交换。也就是key变成值,值变成key。
# 输入:{'a':1,'b':2,‘c':3}
# 输出:{1:'a',2:'b',3:'c'}

dic = {'a': 1, 'b': 2, 'c': 3}
print(dic)
print({v: k for k, v in dic.items()})

11.python函数

函数的作用

  • 函数是组织好的,可重复使用的,用来实现单一或相关联功能的代码段
  • 函数能提高应用的模块性和代码的重复利用率
  • python 内置函数:https://docs.python.org/zh-cn/3.8/library/functions.html

 函数定义

  • def:函数定义关键词
  • function_name:函数名称
  • ():参数列表放置的位置,可以为空
  • parameter_list:可选,指定向函数中传递的参数
  • comments:可选,为函数指定注释
  • function_body:可选,指定函数体

def function_name([parameter_list]):
    [''' comments ''']
    [function_body] 

定义函数的注意事项

  • 缩进:python 是通过严格的缩进来判断代码块儿
    • 函数体和注释相对于 def 关键字必须保持一定的缩进,一般都是 4 个空格
    • pycharm 自动格式化快捷键:ctrl+alt+L
  • 定义空函数
    • 使用 pass 语句占位
    • 写函数注释 comments

函数调用

function_name([parameter_value])

  • function_name:函数名称
  • parameter_value:可选,指定各个参数的值

 参数传递

  • 形式参数:定义函数时,函数名称后面括号中的参数
  • 实际参数:调用函数时,函数名称后面括号中的参数
# a, b, c 为形式参数
def demo_func(a, b, c):
    print(a, b, c)


# 1, 2, 3 为实际参数
demo_func(1, 2, 3)

位置参数

  • 数量必须与定义时一致
  • 位置必须与定义时一致
def demo_func(a, b, c):
    print(a, b, c)


# 1 赋值给 a, 2 赋值给 b, 3 赋值给 c
demo_func(1, 2, 3)

关键字参数

  • 使用形式参数的名字确定输入的参数值
  • 不需要与形式参数的位置完全一致
def demo_func(a, b, c):
    print(a, b, c)


demo_func(a=1, b=2, c=3)

为参数设置默认值

  • 定义函数时可以指定形式参数的默认值
  • 指定默认值的形式参数必须放在所有参数的最后,否则会产生语法错误
  • param=default_value:可选,指定参数并且为该参数设置默认值为 default_value

 def function_name(..., [param=default_value]):

         [function_body]        

 函数返回值

- value:可选,指定要返回的值

def function_name([parameter_list]):
    [''' comments ''']
    [function_body]
    return [value]
def sum(a, b):
    result = a + b
    return result

ret = sum(1, 3)
print(ret)

12.python函数进阶与参数处理

可变参数

  • 可变参数也称为不定长参数
  • 传入函数中实际参数可以是任意多个
  • 常见形式
    • *args
    • **kwargs

*args

  • 接收任意多个实际参数,并将其放到一个元组中
  • 使用已经存在的列表或元组作为函数的可变参数,可以在列表的名称前加*
def print_language(*args):
    print(args)


print_language("python", "java", "php", "go")

params = ["python", "java", "php", "go"]
print_language(*params)

**kwargs

  • 接收任意多个类似关键字参数一样显式赋值的实际参数,并将其放到一个字典中
  • 使用已经存在字典作为函数的可变参数,可以在字典的名称前加**
def print_info(**kwargs):
    print(kwargs)


print_info(Tom=18, Jim=20, Lily=12)

params = {'Tom': 18, 'Jim': 20, 'Lily': 12}
print_info(**params)

13.pythonlambda表达式

匿名函数

  • 没有名字的函数
  • 用 lambda 表达式创建匿名函数

使用场景

  • 需要一个函数,但是又不想费神去命名这个函数
  • 通常在这个函数只使用一次的场景下
  • 可以指定短小的回调函数

 语法

  • result:调用 lambda 表达式
  • [arg1 [, arg2, …. , argn]]:可选,指定要传递的参数列表
  • expression:必选,指定一个实现具体功能的表达式

result = lambda [arg1 [, arg2, .... , argn]]: expression 

# 1.常规写法
def cricle_area(r):
    result = math.pi * r * r
    return result

r = 2
print(f"半径为{r}的圆的面积为{cricle_area(r)}")

# 2.使用lambda表达实现
r = 2
result = lambda r: math.pi * r * r
print(f"半径为{r}的圆的面积为{result(r)}")
print(lambda r: math.pi * r * r)
# 对获取到的信息进行排序
# #书籍信息
book_info = [("python零基础入门", 22.5), ("java 零基础入门", 20), ("软件测试零基础入门", 25)]
print(type(book_info))
print(book_info)

# 指定规则进行排序 
# 第一个x表示一个对象,比如("python零基础入门", 22.5)
# 第二个x表示对象的索引
book_info.sort(key=lambda x: (x[1]))
print(book_info)

14.python面向对象概念

面向对象是什么?

  • Python 是一门面向对象的语言
  • 面向对象编程(OOP):Object Oriented Programming

所谓的面向对象,就是在编程的时候尽可能的去模拟真实的现实世界,按照现实世界中的逻辑去处理问题,分析问题中参与其中的有哪些实体,这些实体应该有什么属性和方法,我们如何通过调用这些实体的属性和方法去解决问题。 

两种编程思想

  • 面向过程
    • 一种以过程为中心的编程思想
    • 首先分析解决问题所需要的步骤
    • 然后用函数将这些步骤一步一步的实现
    • 最后按顺序依次调用运行
  • 面向对象
    • 是一种更符合我们人类思维习惯的编程思想
    • 面向对象开发就是不断的创建对象,使用对象,操作对象做事情
    • 可以将复杂的事情简单化

 类与对象

  • 类(class): 用来描述具有相同的属性和方法的对象的集合。它定义了集合中每个对象所共有的属性和方法。

  • 对象(object):也称为类的实例,是一个具体存在的实体。

15.python类与对象

类的定义

  • class 关键字

# 语法

class 类名(父类名):

"""类的帮助信息"""

属性

方法 

# 类的声明
class Human(object):
    """人类"""

    # 定义属性(类属性)
    message = "这是类属性"


# 通过类访问类属性
print(Human.message)

类的方法

  • 实例方法
    • 构造方法
  • 类方法
  • 静态方法

构造方法与实例化

  • 作用:实例化对象
  • 语法:def __init__(self, 参数列表)
  • 访问:类名(参数列表)
class Human:
    # 定义属性(类属性)
    message = "这是类属性"

    # 构造方法
    def __init__(self, name, age):
        # 实例变量
        self.name = name
        self.age = age
        print("这是构造方法")


# 实例化对象
person = Human("哈利波特", 12)

# 通过实例访问类属性
print(person.message)

# 通过实例访问实例属性
print(person.name)
print(person.age)

实例方法

  • 作用:提供每个类的实例共享的方法
  • 语法:def 方法名(self, 参数列表)
  • 访问:实例.方法名(参数列表)
class Human:

    # 实例方法
    def study(self, course):
        print(f"正在学习{course}")


# 实例化
person = Human()

# 通过实例访问实例方法
person.study("python")

 类方法

  • 作用:可以操作类的详细信息
  • 语法:@classmethod
  • 访问:类名.类方法名(参数列表)
class Human:
    # 类属性
    population = 0

    # 类方法
    @classmethod
    def born(cls):
        print("这是类方法")
        cls.population += 1


# 通过类名访问类方法
Human.born()
print(Human.population)

 静态方法

  • @staticmethod
class Human:

    # 静态方法
    @staticmethod
    def grow_up():
        print("这是静态方法")


# 通过类名访问静态方法
Human.grow_up()

16.学生信息管理系统

  1. 编写学员实体类 Student,对应成员变量包含:学号 id、姓名 name、性别 sex;

  2. 编写学员管理类 StudentManagement ,实现添加学员方法 addStudent()。

  3. 编写StudentManagement的main方法进行学员信息的添加:

    学号:1001,姓名:张三,性别:男。
    学号:1002,姓名:莉丝,性别:女。
    学号:1003,姓名:王武,性别:男。
class Student:
    def __init__(self, id, name, sex):
        self.id = id
        self.name = name
        self.sex = sex


class StudentManagement:

    def __init__(self):
        pass

    def addStudent(self, id, name, sex):
        student = Student(id, name, sex)
        print(f"添加学员成功:{student.id}, {student.name}, {student.sex}")

    def main(self):
        # 添加学员1
        self.addStudent(1001, "张三", "男")
        # 添加学员2
        self.addStudent(1002, "莉丝", "女")
        # 添加学员3
        self.addStudent(1003, "王武", "男")


stumg = StudentManagement()
stumg.main()

运行结果:

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/818263.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【7.31】C++编写7254是一个不寻常的数,可以表示为7254 = 39 x 186,这个式子中1~9每个数字正好出现一次

题目题干 7254是一个不寻常的数&#xff0c;因为它可以表示为7254 39 x 186&#xff0c;这个式子中1~9每个数字正好出现一次&#xff0c;输出所有这样的不同的式子&#xff08;乘数交换被认为是相同的式子&#xff09;。结果小的先输出&#xff1b;结果相同的&#xff0c;较小…

IPsec VPN小实验

IPSec 是什么&#xff1a; IPSec是一个框架&#xff0c;它不是具体指某个协议&#xff0c;而是定义了一个框架&#xff0c;由各种协议组和协商而成。该框架涉及到的主要有加密算法、验证算法、封装协议、封装模式、密钥有效期等等。 IPSecVPN建立的前提&#xff1a;要想在两个…

【性能测试】性能测试的概念、策略、指标

一、性能测试的概念 1.1 什么是性能 - 时间&#xff1a;系统处理用户请求的响应时间 -资源&#xff1a;系统运行过程中&#xff0c;系统资源的消耗情况 1.2 什么是性能测试 使用自动化工具&#xff0c;模拟不同的场景&#xff0c;对软件各项性能指标进行测试和评估的过程 …

适配器模式与装饰器模式对比分析:优雅解决软件设计中的复杂性

适配器模式与装饰器模式对比分析&#xff1a;优雅解决软件设计中的复杂性 在软件设计中&#xff0c;我们常常面临着需要将不同接口或类协调工作的情况&#xff0c;同时还要满足灵活性和可扩展性的需求。为了应对这些挑战&#xff0c;适配器模式和装饰器模式应运而生&#xff0c…

12-4_Qt 5.9 C++开发指南_创建和使用共享库

文章目录 1. 创建共享库2. 使用共享库2.1 共享库的调用方式2.2 隐式链接调用共享库2.3 显式链接调用共享库 1. 创建共享库 除了静态库&#xff0c;Qt 还可以创建共享库&#xff0c;也就是 Windows 平台上的动态链接库。动态链接库项目编译后生成 DLL 文件&#xff0c;DLL 文件…

【机器学习】Overfitting and Regularization

Overfitting and Regularization 1. 过拟合添加正则化2. 具有正则化的损失函数2.1 正则化线性回归的损失函数2.2 正则化逻辑回归的损失函数 3. 具有正则化的梯度下降3.1 使用正则化计算梯度&#xff08;线性回归 / 逻辑回归&#xff09;3.2 正则化线性回归的梯度函数3.3 正则化…

SpringCloud集成OpenTelemetry的实现

SpringCloud项目做链路追踪&#xff0c;比较常见的会集成SleuthZipKin来完成&#xff0c;但这次的需求要集成开源框架OpenTelemetry&#xff0c;这里整理下实现过程。相关文章&#xff1a; 【SpringCloud集成SleuthZipkin进行链路追踪】 【OpenTelemetry框架Trace部分整理】 …

JavaSE运算符

大体上&#xff0c;与C语言差不多&#xff0c;不同的地方&#xff0c;我用红色字体标注了 算术运算符 1. 基本四则运算符&#xff1a;加减乘除模 ( - * / %) int a 10 ; int b 20 ; System . out . println ( a b ); // 30 System . out . println ( a - b…

校园跑腿小程序开发需要哪些核心功能?

提起校园跑腿小程序大家都不陌生&#xff0c;尤其是对上大学的伙伴们来说,更是熟悉得不能再熟悉了&#xff0c;和我们的生活息息相关&#xff0c;密不可分。 对于现在的年轻人来说&#xff0c;网购是非常简单和方便的一种购物方式&#xff0c;随之快递也会越来越多。在我们国家…

白盒测试和黑盒测试的区别是什么?

前言 曾言道“黑猫&#xff0c;白猫&#xff0c;只要能抓住老鼠就是好猫”。我们的测试亦是如此&#xff0c;不管是黑盒测试还是白盒测试&#xff0c;只要能测试出来bug&#xff0c;可以找出问题所在&#xff0c;保障软件质量就是好的测试方法。 对于刚入门的软件测试小白来说…

【Git系列】Git到远程仓库

&#x1f433;Git到远程仓库 &#x1f9ca;1. github账号注册&#x1f9ca;2. 初始化本地仓库&#x1f9ca;3. 创建GitHub远程仓库&#x1f9ca;4. 给本地仓库起别名&#x1fa9f;4.1 查看远程库的连接地址&#x1fa9f;4.2 起别名 &#x1f9ca;5. git推送操作&#x1f9ca;6.…

【SEO基础】百度权重是什么意思及网站关键词应该怎么选?

百度权重是什么意思及网站关键词应该怎么选&#xff1f; 正文共&#xff1a;3253字 20图 预计阅读时间&#xff1a;9分钟 ​ 1.什么是网站权重&#xff1f; 这段时间和一些朋友聊到网站权重以及关键词&#xff0c;发现蛮多人对于这两个概念的认知还是存在一些错误的&#xf…

【Python】PySpark 数据计算 ② ( RDD#flatMap 方法 | RDD#flatMap 语法 | 代码示例 )

文章目录 一、RDD#flatMap 方法1、RDD#flatMap 方法引入2、解除嵌套3、RDD#flatMap 语法说明 二、代码示例 - RDD#flatMap 方法 一、RDD#flatMap 方法 1、RDD#flatMap 方法引入 RDD#map 方法 可以 将 RDD 中的数据元素 逐个进行处理 , 处理的逻辑 需要用外部 通过 参数传入 map…

RL— 深度强化学习简介

一、说明 深度强化学习是关于从我们看到和听到的东西中采取最好的行动。不幸的是&#xff0c;强化学习强化学习在学习概念和术语方面存在很高的障碍。在本文中&#xff0c;我们将介绍深度强化学习&#xff0c;并概述一般情况。然而&#xff0c;我们不会回避方程式和术语。它们提…

Linux虚拟机中安装MySQL5.6.34

目录 第一章、xshell工具和xftp的使用1.1&#xff09;xshell下载与安装1.2&#xff09;xshell连接1.3&#xff09;xftp下载安装和连接 第二章、安装MySQL5.6.34&#xff08;不同版本安装方式不同)2.1&#xff09;关闭防火墙&#xff0c;传输MySQL压缩包到Linux虚拟机2.2&#x…

canvas实现图片平移,缩放的例子

最近有个水印预览的功能&#xff0c;需要用到canvas 绘制&#xff0c;canvas用的不是很熟&#xff0c;配合chatAI 完成功能。 效果如下 代码如下 原先配置是响应式的&#xff0c;提出来了就不显示操作了&#xff0c;模拟值都写死的 界面给大家参考阅读。 <!DOCTYPE html…

springboot基础--springboot配置说明

一、springboot中的配置文件 1、springboot为什么还需要用配置文件 方便我们修改springboot默认的配置;我们有其他的信息需要保存在配置文件中; 2、springboot中的配置文件有哪些 properties配置文件;yml配置文件; 3、springboot中的配置文件使用中注意事项 文件放入在sr…

黑客技术(网络安全)学习笔记

一、网络安全基础知识 1.计算机基础知识 了解了计算机的硬件、软件、操作系统和网络结构等基础知识&#xff0c;可以帮助您更好地理解网络安全的概念和技术。 2.网络基础知识 了解了网络的结构、协议、服务和安全问题&#xff0c;可以帮助您更好地解决网络安全的原理和技术…

Java版本spring cloud + spring boot企业电子招投标系统源代码+ 支持二次开+定制化服务

&#xfeff; 电子招标采购软件 解决方案 招标面向的对象为供应商库中所有符合招标要求的供应商&#xff0c;当库中的供应商有一定积累的时候&#xff0c;会节省大量引入新供应商的时间。系统自动从供应商库中筛选符合招标要求的供应商&#xff0c;改变以往邀标的业务模式。招…

在当下Android 市场下行时,能拿到offer实属不易~

作者&#xff1a;六哥 如今 Android 已不是前几年那么风光&#xff0c;但它的市场还在&#xff0c;“它”还是那个Android&#xff0c;还是那个我赖以生存、夜以继日陪伴着我的朋友。所以&#xff0c;我永远不会抛弃它。 好了&#xff0c;情感已经抒发的差不多了&#xff0c;我…