当前位置: 首页 > news >正文

Python 学习笔记——代码基础

目录

Python基础知识

变量

赋值

数据类型

print用法 

print格式化输出

运算符

if-else

数据结构

 元组

in运算符

 列表

切片 [ : ]

追加 append()

插入 insert()

删除 pop()

字典 

循环

for循环

for循环应用——遍历

for循环应用——累加

for循环应用——计数器

while循环

for 和 while 的区别

终止循环

嵌套循环

函数

定义函数

调用函数

形参与实参

函数返回值

必选参数

匿名函数

递归

类与对象

类的属性与初始化


Python基础知识

变量

变量就像容器,能够存储各种类型的数据。

变量名只能由大小写字母,数字和下划线组成。需要注意:

1.不能以数字开头 2.不能包含空格 3.大小写敏感,变量A和变量a是不同的

赋值

将数据放入变量的过程,叫作赋值,赋值运算符是 =。

可以把常量赋值给变量, 也可以把变量赋值给变量, 还可以把运算结果赋值给变量。

数据类型

数据类型:整型,浮点型,布尔数,字符串。

这四种数据类型分别对应不同的应用场景。

整型和浮点型用于数字的表示和计算; 布尔数用于逻辑判断和运算; 字符串用来进行文本处理。

print用法 

print()的括号里,是要输出的内容。这个内容可以是常量,也可以是变量,甚至是运算的结果。

字符串常量可以使用双引号 " ",单引号 ' ' 来表示。

双引号和单引号的功能相同,唯一的区别是,当字符串的内容已包含单引号时,我们可以使用双引号将内容括起来,反之同理。

print()函数中,字符串不能直接使用回车进行换行,否则系统会报错。

如需要换行,需要在换行处使用转义字符中的 \n

print格式化输出

除了可以直接使用print()输出,还可以通过格式化输出的方式来对字符串进行“填空”。 



格式化输出的语法如图:

1.在字符串常量前添加小写字母f

2.字符串中需要“填空”的地方使用大括号 { } 括起来

3.将需要填空的变量填入大括号 { } 中

eg:

name = "James"
age = 20# 使用字符串格式化输出,在屏幕上输出: James is 20 years oldprint(f"{name} is {age} years old")

运算符

加+、减-、乘*、除/

取模 % 表示运算结果为两数相除结果的余数。

取整 // 表示运算结果为两数相除结果的商。

比较运算符
大于>
小于<
等于==
大于等于>=
小于等于<=
不等于!=

逻辑运算符一共有三个,分别是:

and(并且)——两边的布尔数均为真时才为真,其他情况为假。

or(或者)——两边的布尔数至少有一个为真时为真,两边的布尔数都是假时才为假。

not(非)——仅有一个布尔数参与运算,结果为对这个布尔数取反。

if-else

if ():xxxxxxxxxxxx
elif ():xxxxxxxxx
else: xxxxx

容易犯的错误:

1. 语法错误
else 后面的冒号常常被遗漏,这是if-else的固定格式,有冒号程序才知道下面是 else 的代码块。

2. 缩进问题
if 和 else 为互斥关系,if和else 后面的代码块需要通过缩进形成。

3. 如果多个if都能满足,只执行第一个if。(越靠前的if应该越难满足)

数据结构

 元组

 

元组=(,,,,,) 

元组中的数据是有顺序的。也就是说,如图在calendar这个元组里面,排在第一位的是"1月1日",第二位是"1月2日",第三位的是"1月3日"。第四位的是"1月4日"。

当我们输出calendar[0]的时候,就得到了这个元组的第一个数据。像这样访问它内部数据的机制,叫做“索引”。

 索引是在数据结构中用来定位和寻找数据的检索方式。索引都是从0开始的。

可以通过中括号[]和索引的方式,直接访问到某一个位置的元素。

in运算符

快速判断某一个数据,是不是在元组中

numbers = (0,1,2,3,5,8,13,21,34,55,89,144,233,377)
#判断 5是否是元组中的一个元素
result = 5 in numbers
print(result)

 列表

 

列表=【,,,,,】 

列表中的数据可以是整型,浮点型,字符串或布尔数的任意组合。

列表的修改:

 列表的修改不能应用于元组中,元组具有不可变的特性。

元组的内容定义完成后,里面的内容就不能修改。

切片 [ : ]

编程中的切片能对元组、列表等有序数据结构进行处理,以截取数据中连续的片段,方便使用。

切片要遵循“左闭右开”原则,就是取左边的数据,不取右边的数据,与数学中的区间类似[1, 3),取左不取右。

注意:切片与索引类似,也是从0开始,即第一个元素的索引为0。

 例如,第2行中的someLetters[1:3],索引从0开始,这里就是取第2个元素到第4个元素。

又需要遵循“左闭右开”原则,则取第2个到第3个元素,输出['b', 'c']。

切片时,开始位置和结束位置的数字,还有三种填写情况:
1. 只填写结束位置的数字;
2. 只填写开始位置的数字;
3. 两侧数字都不填写。


1. 开始位置数字不填,默认从第一个元素开始切片。根据“左闭右开”原则,如图,从第一个元素(含)开始,取到第三个元素(含)。

 2. 结束位置数字不填,默认从开始位置切片,取到最后一个元素。

注意:不填写结束位置的数字时,列表中最后一个元素也会被提取。如图,表示从第二个元素(含)开始,到最后一个元素(含)结束。

3. 开始位置和结束位置都不填写时,就是取列表中的所有元素。

追加 append()

追加一般用于描述在列表的末尾添加元素的行为。

使用 append() 可以追加不同数据类型,包括:字符串、整型、浮点型、元组以及列表等。

使用 append() 一次只能追加一个元素。

插入 insert()

 

我们需要在 insert() 的括号中填入两项内容:
第一项是元素插入的位置;
第二项是插入的具体数据。

插入元素以后,排在此元素之后的原有元素自动后移一位。

删除 pop()

括号内的数字表示要删除数据的索引,不填写数字则表示默认删除列表中的最后一个数据。

字典 

在Python中,将两种数据关联在一起形成一个元素, 由多个这样的元素组成的数据类型称为字典,又称为dict。

字典中的元素是不考虑排列顺序的。

组成字典元素(item)的两个数据一一对应,分别被称为键(key) 与值(value),所以字典的元素又称为键值对(key-value)。

字典的元素只能通过键来查找对应的值,所以一个键只能对应一个值。

 在Python中,字典的键值对由冒号分割。冒号左边的数据为键,冒号右边的数据为值。

将多个这样的数据以逗号分割,存储到一个大括号中,就形成了一个字典类型。

查找【】

字典是没有顺序的,也就没有索引,所以只能通过字典的键(key)来查找对应的值(value)

删除还是用pop():

 字典的键是不能重复的。当我们尝试添加一个已经存在的键时,就会将该元素覆盖。

添加或修改:【】



对字典的修改,就是对字典的某个已经存在的键重新赋值。

查看字典里的键 

 

 keys()是字典的一个功能,它能够提取一个字典所有的键,并存储在一个类似于列表的名为dict_keys的数据中,方便我们查看该字典的键。

除了使用“keys()”以外,我们也可以通过in运算来检查字典是否包含某个键。

循环

for循环

numberList = [10, 20, 30, 40, 50, 60]for number in numberList:   print(number)

 当程序执行完 for 循环后,如果同一层级(缩进一致)还有代码未执行,则按照顺序,继续自上而下执行。

name = ["david","bob","bill"]
for i in name:print(i)
print(i)#输出 david  bob  bill  bill

第一个print()是for循环内部的输出。每进行一次循环就会执行输出i的值一次。

第二个print()和for循环处于同一层级。当for循环结束以后,程序跳出循环,才会执行输出,输出最后一次循环结束时i的值。

for循环应用——遍历

遍历是指通过某种顺序对一个数据结构中的所有元素进行访问。

for循环不仅可以遍历列表,还可以遍历字典、元组、甚至字符串等数据结构。

遍历元组和字符串与遍历列表的代码几乎一样,也是逐个获取元组或字符串的每个字符。

 for 循环遍历字典稍微有一些区别。

字典是键值对的组合,那么对字典的遍历就包含【键,值,键和值】三种情况。

遍历字典的键

for 循环遍历字典的键,有两种方法可以使用:

1. for 循环遍历字典;
这个方法和 for 循环遍历列表的格式类似。

2. for循环遍历字典中的所有键;
使用 for 循环遍历 dict.keys(),将字典中的键赋值给变量,再通过 print() 输出变量。

遍历字典的值

遍历字典的值,我们可以通过查字典的方式,也就是通过字典的键找到对应指定的值。

首先使用 for 循环遍历字典,将键赋值给变量,通过dict[键]的方式找到对应的值,并赋值给新的变量。

接着使用 print() 输出这个变量,即可遍历字典的值。

遍历字典的键和值

刚才我们使用 for 循环遍历字典的键和字典的值,如果想要同时输出字典的键和值,该怎么办呢?

这时,我们可以在循环内部分别输出字典的键和对应的值。

注意,在 for 循环中,一次循环会把循环内的代码全部执行完后,再开始下一次循环。

for i in range()

for i in range()的功能是:遍历一个整数列表。

其中range()的功能是:创建一个整数列表。

例如:range(5)可以生成一个从0 开始到5结束但不包括5的整数列表[0,1,2,3,4]

for i in range(5):print(i)

range()功能中可以填写2个内容,range(a,b)。
a: 计数从 a 开始。默认是从 0 开始,可省略。
b: 计数到 b 结束,但不包括 b,不可省略。


 

for循环应用——累加

jdList = [3, 1.5, 4, 2]
total = 0
for price in jdList:total = total + price
print(total)#这5行代码的功能就是,计算列表中的所有元素的总和并输出。

 用一个变量来存储总和,第2行定义变量 total ,将0赋值给变量,这个过程就是设置初始值
注意:这里的初始值需要定义在 for 循环的外侧,若定义在 for 循环中,每次循环变量都会重新赋值。

for循环应用——计数器

# 定义存储学生姓名的列表
students = ["Tom", "Blue", "Max", "Shufen", "Joe", "Tim"]# TODO 定义变量count,初始值为0
count =0# TODO 使用for循环变量列表
for name in students:# TODO count值加1,赋值给countcount=count+1# TODO 使用格式化输出print(f"第{count}名是{name}")

while循环

条件循环,又称while循环,以判断条件是否成立,来决定是否执行循环内的代码。

当判断为真时,代码会循环执行,当判断为假时则终止循环。

 while循环中,有一个判断条件,来决定是否执行循环内的代码。

判断为True,则继续执行循环;
判断为False,就会中止循环。

这样的判断条件,我们称为——边界条件

nameList = ["Max","Tom","Jim","Ken","Kim"]
counter = 0
while counter < 5:print(nameList[counter])counter = counter + 1#使用了while循环把列表的元素全部输出出来

for 和 while 的区别

第一个区别:
for循环是在每一次循环的时候,按照从头到尾的顺序自动遍历,给变量name赋值列表中的元素;

而while循环是用一个计数器来索引列表,分别访问这个列表里面的每个元素。

 

第二个区别:
循环的终止条件不一样。

for循环的终止条件是遍历完这个列表;

while循环的终止条件是边界条件,counter<5,当边界条件为True的时候继续执行代码,为False的时候就终止执行。

终止循环

break

break语句既可以用在for循环中也可以用在while循环中。

它一般和if语句搭配在一起使用,表示如果满足了某种特定条件,就直接终止当前的循环结构。 

numberList = [10, 4, 1, 20, 6]
for i in numberList:print(i)if i > 15:break
print(numberList)#这六行代码遍历了一个列表numberList,并依次输出其中的元素。#第2-5行是一个完整的for循环结构。如果列表中有大于15的元素,就终止循环结构。#for循环外,输出了完整的numberList。

continue

 continue会“跳过”本次循环内的剩余代码。

drinks = ["water", "coke", "tea", "milk"]
for item in drinks:if item == "coke":continueprint(item)这5行代码遍历了一个列表drinks。第2-5行是一个完整的循环结构。在循环内,通过if语句判断该列表中是否有元素是"coke"。如果有,则跳过本次循环中的剩余代码,也就是第5行的print(item),直接进入到下一次循环。如果没有,就执行print(item),然后进入下一次循环,直到列表drinks中所有元素都被取完为止。

break 和 continue 区别

当执行break时,会跳出整个循环结构,并运行循环外的第一行代码。

执行continue时,会“跳过”本次循环内的剩余代码,返回到循环的开头,继续执行下一次循环。

嵌套循环

嵌套循环的特征是:对于外循环的每次迭代,内循环都要完成它的所有迭代。

brandList = ["Ja mer","Cbp","SK3"]
itemList = ["精华","面霜","眼霜","爽肤水"]
for brand in brandList:for item in itemList:print(f"恭喜你将获得{brand}品牌的{item}一份")
恭喜你将获得Ja mer品牌的精华一份
恭喜你将获得Ja mer品牌的面霜一份
恭喜你将获得Ja mer品牌的眼霜一份
恭喜你将获得Ja mer品牌的爽肤水一份
恭喜你将获得Cbp品牌的精华一份
恭喜你将获得Cbp品牌的面霜一份
恭喜你将获得Cbp品牌的眼霜一份
恭喜你将获得Cbp品牌的爽肤水一份
恭喜你将获得SK3品牌的精华一份
恭喜你将获得SK3品牌的面霜一份
恭喜你将获得SK3品牌的眼霜一份
恭喜你将获得SK3品牌的爽肤水一份

函数

函数是指封装了某一特定功能的代码块。

简单的讲,函数就是用来存储代码的“特殊变量”。

定义函数

#这3行代码做的事情是定义了一个叫做“sayWelcome”的函数。def sayWelcome():   #def是函数定义的关键字,是define的缩写。print("欢迎光临")print("商品一律九折")

调用函数

形参与实参

形参是形式参数的简称,指定义函数时设置的参数名称。

实参是实际参数的简称,指调用函数时实际传递的数据。

# TODO 定义一个函数 sayHi
def sayHi(name):# TODO 格式化输出 "尊敬的会员{name}!"print(f"尊敬的会员{name}!")# TODO 输出 "欢迎进入我的网站"print("欢迎进入我的网站")# TODO 调用sayHi函数,并传递参数"Tony"
sayHi("Tony")
# TODO 调用sayHi函数,并传递参数"Gary"
sayHi("Gary")

 参数可以定义多个,也可以不定义。

如果参数不止一个,多个参数之间可以用英文逗号“,”隔开。

函数返回值

在函数中,使用关键字 return 设置要返回的数据。

return 位置一般都是在函数的末尾,这样才能停止函数内的代码运行并将 return 后的值返回。

return 后面是指定的返回值,返回值会返回到调用的地方。

# 定义函数sayHello(),传入参数name
def sayHello(name):# 将"Hello!"与name字符串拼接,赋值给变量resultresult = "Hello!" + name# 返回变量resultreturn result# 调用sayHello(),传入"Mary",并输出
print(sayHello("Mary"))
# 调用sayHello(),传入"Jack",并输出
print(sayHello("Jack"))

函数经过内部代码的执⾏会产⽣一个结果,这个结果可以是一个具体的值也可以是多个值。

当函数同时返回多个值时,以逗号 "," 隔开,并且返回值以元组的格式返回。

函数名

为函数取名是为了方便我们重复使用。在 Python 中,函数的命名规则和变量类似。

 

必选参数

函数的一种参数类型,在调用这个函数的时候必须传入数据的参数。

 在传递必选参数时,形参会按照定义的顺序依次接收数据。

在调用函数时,缺少或超出对必选参数的传递会导致程序错误。也就是说,在函数中定义了多少个必选参数就要传递多少个实参。 

当我们忘记了传递顺序时,可以利用“形参名=实参名”的方式传递实参。这样以关键字传递实参的形式,简称为关键字实参。

匿名函数

 匿名函数是一种不需要为函数命名的函数定义方式,以 lambda 关键字开头。

 注意:lambda后面要空格,用到几个参数就需要写几个字母

area=lambda L,G,H:L*H*G
print(area(10,8,6))#定义一个“匿名函数”,它的功能是计算立方体的体积,其公式为:长*宽*高,将匿名函数赋值给变量 area。然后传入参数10, 8, 6,并输出计算结果。

递归

一段程序调用自身的过程我们叫做递归,多见于函数调用函数自身。

# TODO 定义名为sum()函数,传入参数n
def sum(n):# TODO 如果n小于等于0if(n<=0):# TODO 返回0return 0# TODO 返回n加上sum(n-1)return n+sum(n-1)# TODO 调用sum()传入200并输出
result=sum(200)
print(result)
def factorial(num):if num <= 1:return 1return num * factorial(num-1)print(factorial(10))
#写一个递归函数可以实现阶乘(factorial),计算10的阶乘。

类与对象

代表一些拥有相同特性与功能的事物,如鸟类,人类,猫类等。

类中的某一个具体实例称为这个类的实例对象,简称为对象

属性用来描述这个类的一些特征,如品牌,颜色,型号是手机的属性。

方法用来表现这个类的一些功能,如拍照,打电话等是手机的方法。

eg:

用class定义一个类,并命名为Phone。

第2~6行,为该类添加了打电话和发短信两个功能。即定义了两个方法makeCall与sendMsg。

第2,3行,makeCall方法接收联系人的名字为参数,并将文字格式化输出。

第5,6行,sendMsg方法接收联系人的名字与短信内容为参数,并将文字格式化输出

class Phone():def makeCall(self, who): return f"正在拨打电话给{who}"def sendMsg(self, who, txt):return f"正在发送短信给{who}, 内容为{txt}"

将刚才定义好的Phone类拿过来,并实例化两个对象myPhone与yourPhone。

第9,10行,创建Phone的对象myPhone与yourPhone。

第12行,调用myPhone的方法makeCall,把结果存储到ret中。

第14行,调用yourPhone的方法sendMsg,把结果存储到ret2。

class Phone():def makeCall(self, who):return f"正在拨打电话给{who}"def sendMsg(self, who, txt):return f"正在发送短信给{who}, 内容为{txt}"myPhone = Phone()
yourPhone = Phone()ret = myPhone.makeCall("Tony")
print(ret)
ret2 = yourPhone.sendMsg("Jeremy", "中午吃啥?")
print(ret2)

 

类的属性与初始化

eg:

为Phone类添加品牌(brand)与颜色(color)两个属性。

第2行,定义初始化方法__init__并设定两个参数bd与clr。

第8,9行,创建实例化对象myPhone与yourPhone,并为__init__方法传递参数两组不同的参数。

第10,11行,分别格式化输出实例对象的color与brand属性

class Phone():def __init__(self, bd, clr):print("创建实例对象时,自动调用此方法")self.brand = bdself.color = clrmyPhone = Phone("华为", "白色")
yourPhone = Phone("苹果", "黑色")
print(f"我有一个{myPhone.color}的{myPhone.brand}手机")
print(f"你有一个{yourPhone.color}的{yourPhone.brand}手机")

初始化方法__init__,是一个特殊的方法。

init 的左右两边各有两个下划线,即整个名称共有四个下划线。

初始化类似于出厂设置,表示“开始时做好准备”,会在创建对象时自动被调用。

相关文章:

Python 学习笔记——代码基础

目录 Python基础知识 变量 赋值 数据类型 print用法 print格式化输出 运算符 if-else 数据结构 元组 in运算符 列表 切片 [ : ] 追加 append() 插入 insert&#xff08;&#xff09; 删除 pop() 字典 循环 for循环 for循环应用——遍历 for循环应用——累加…...

Android Studio 无法正常导入项目

Android Studio 无法正常导入 model&#xff0c;运行按钮边出现“Add Configuration”&#xff0c;可进行以下方法处理&#xff1a; 解决办法&#xff1a; 1、点击Run三角按钮左边紧挨的下拉按钮&#xff0c;选择Edit Configuration&#xff0c;选择 Default 新建一个Android…...

Grafana+Prometheus技术文档-进阶使用-监控spring-boot项目

阿丹&#xff1a; 之前已经实现了使用Prometheus来对服务器进行了监控和仪表盘的创建&#xff0c;现在就需要对这些监控方法使用在spring-boot中去。 实现思路&#xff1a; 1、集成Actuator 2、加入Prometheus的依赖 3、配置开放端口、以及开放监控 4、配置Prometheus中的配置…...

PG常用SQL

数据库 创建数据库 PostgreSQL 创建数据库可以用以下三种方式&#xff1a; 1、使用 CREATE DATABASE SQL 语句来创建。2、使用 createdb 命令来创建。3、使用 pgAdmin 工具。 CREATE DATABASE 创建数据库 CREATE DATABASE 命令需要在 PostgreSQL 命令窗口来执行&#xff0…...

分模块开发的意义及开发步骤

&#x1f40c;个人主页&#xff1a; &#x1f40c; 叶落闲庭 &#x1f4a8;我的专栏&#xff1a;&#x1f4a8; c语言 数据结构 javaweb 石可破也&#xff0c;而不可夺坚&#xff1b;丹可磨也&#xff0c;而不可夺赤。 Maven进阶 一、分模块开发1.1分模块开发的意义1.2分模块开…...

vue-router中的一些 API

在Vue.js的vue-router中&#xff0c;一些重要api 1、RouterHistory&#xff1a;这是 vue-router 提供的路由历史记录对象。它可以跟踪当前页面的路由历史&#xff0c;并提供一些方法和属性来管理导航和历史记录。在 vue-router 中&#xff0c;有两种类型的路由历史记录对象&…...

go-zero 是如何实现令牌桶限流的?

原文链接&#xff1a; 上一篇文章介绍了 如何实现计数器限流&#xff1f;主要有两种实现方式&#xff0c;分别是固定窗口和滑动窗口&#xff0c;并且分析了 go-zero 采用固定窗口方式实现的源码。 但是采用固定窗口实现的限流器会有两个问题&#xff1a; 会出现请求量超出限…...

Oracle/PL/SQL奇技淫巧之ROWNUM伪列

ROWNUM伪列 ROWNUM是一个伪列&#xff0c;它是根据每次查询的结果动态生成的一列递增编号&#xff0c;表示 Oracle 从表中选择该行的顺序&#xff0c;选择的第一行ROWNUM为1&#xff0c;第二行ROWNUM为2&#xff0c;以此类推。 注意1&#xff1a; ROWNUM伪列是在WHERE子句之…...

“MongoDB基础知识【超详细】

"探索MongoDB的无边之境&#xff1a;沉浸式数据库之旅" 欢迎来到MongoDB的精彩世界&#xff01;在这个博客中&#xff0c;我们将带您进入一个充满创新和无限潜力的数据库领域。无论您是开发者、数据工程师还是技术爱好者&#xff0c;MongoDB都将为您带来一场令人心动…...

腾讯24届校招内推

校招开始啦&#xff5e;有兴趣的话可以扫我的码投&#xff0c;也可以分享给身边找工作的同学&#xff5e; ❤投递攻略 1️⃣腾讯校招步骤&#xff0c;先微信扫码绑定内推关系&#xff0c;后在电脑上上传更改简历和部门投递 2️⃣投递时将选择投递部门&#xff0c;投递后将在…...

星际争霸之小霸王之小蜜蜂(二)--类的使用

目录 前言 一、将设置内容写在一个类里 二、设置小蜜蜂的造型 三、设置猫蜜蜂的参数 四、绘制猫蜜蜂到窗口 总结 前言 昨天我们设置好了窗口&#xff0c;下面我们需要向窗口中添加元素了。 一、将设置内容写在一个类里 我个人理解书上的意思是要创建一个类&#xff0c;将所有需…...

AndroidStudio升级Gradle之坑

最近在做旧工程的升级&#xff0c;原来的Gradle版本是4.6的&#xff0c;需要升级到7.6&#xff0c;JDK从8升级到17&#xff0c;一路淌了很多坑&#xff0c;逐个记录下吧 1、Maven仓库需要升级到https 你会遇到这个报错 Using insecure protocols with repositories, without …...

C# int ? 关键字使用方法

使用C#的时间也不算短。 但是今天看到了一个从来没有见过的写法 Int &#xff1f;这是个什么写法&#xff0c;没见过啊&#xff0c;百度了查一下&#xff0c;也在这里记录一下。 1、int? 关键字说明 (1)、int? 表示一个int类型,且该int类型可空,如果不加?的话,那么int类…...

Redis_主从复制

8. 主从复制 8.1 简介 主从库采用读写分离的方式 读操作&#xff1a;主库、从库都可以处理写操作&#xff1a;首先写到主库执行&#xff0c;然后再将主库同步给从库。 实现读写分离&#xff0c;性能扩展 容灾快速恢复 8.2 主从复制步骤 创建一个目录 ,在root下创建一个m…...

Postman 的 Pre-request Script 使用RSA加解密

文章目录 一、概述 一、概述 Postman内置的Js不支持进行RSA加解密&#xff0c;所以需要引入forgeJS来实现。在 Pre-request Script使用以下脚本&#xff1a; // ------ 导入RSA ------ if (!pm.globals.has("forgeJS")) {pm.sendRequest("https://raw.githubu…...

【Swagger】只需要3步搭建Swagger环境,就可以让你的项目实现Swagger在线文档,实时浏览,修改展示

目录 1. pom.xml文件中添加Swagger的jar包 2. 配置Swagger 3. 项目启动中加入Swagger注解的开关&#xff0c;启动Swagger功能 4. 启动项目&#xff0c;查看效果 Swagger 的功能这里就不多说明了&#xff0c;相信大家都懂的&#xff0c;好奇多问一句&#xff0c;大家有知道其…...

pytest运行时参数说明,pytest详解,pytest.ini详解

一、Pytest简介 1.pytest是一个非常成熟的全功能的Python测试框架&#xff0c;主要有一下几个特点&#xff1a; 简单灵活&#xff0c;容易上手&#xff0c;支持参数化 2.能够支持简单的单元测试和复杂的功能测试&#xff0c;还可以用来做selenium、appium等自动化测试&#xf…...

Matplotlib绘图知识小结--Python数据分析学习

一、Pyplot子库绘制2D图表 1、Matplotlib Pyplot Pyplot 是 Matplotlib 的子库&#xff0c;提供了和 MATLAB 类似的绘图 API。 Pyplot 是常用的绘图模块&#xff0c;能很方便让用户绘制 2D 图表。 Pyplot 包含一系列绘图函数的相关函数&#xff0c;每个函数会对当前的图像进行…...

mouseover、mouseout和mouseenter、mouseleave之间的区别(配对使用)

以上四个事件都是与鼠标相关的事件&#xff0c;其中mouseenter和mouseover均是鼠标移入时触发的事件&#xff0c;但是使用mouseover的时候会触发冒泡事件&#xff0c;也就是&#xff0c;当父元素和子元素均绑定mouseover事件的时候&#xff0c;如果触发子元素的mouserover事件&…...

【论文阅读】基于深度学习的时序预测——Autoformer

系列文章链接 论文一&#xff1a;2020 Informer&#xff1a;长时序数据预测 论文二&#xff1a;2021 Autoformer&#xff1a;长序列数据预测 论文三&#xff1a;2022 FEDformer&#xff1a;长序列数据预测 论文四&#xff1a;2022 Non-Stationary Transformers&#xff1a;非平…...

【AI】《动手学-深度学习-PyTorch版》笔记(十五):网络中的层、块和参数

AI学习目录汇总 1、什么是块? 在线性模型中,我们关注过单个神经元(单个神经网络的输入和输出); 在多层感知机中,我们关注过整层的神经元(前一层的输出作为后一层的输入); 如果将“多层感知机”视为一整体,称为“块”,可以将前一个块的输出作为后一个块的输入。 块…...

Flink之Task解析

Flink之Task解析 对Flink的Task进行解析前,我们首先要清楚几个角色TaskManager、Slot、Task、Subtask、TaskChain分别是什么 角色注释TaskManager在Flink中TaskManager就是一个管理task的进程,每个节点只有一个TaskManagerSlotSlot就是TaskManager中的槽位,一个TaskManager中可…...

计算机竞赛 python 爬虫与协同过滤的新闻推荐系统

1 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; python 爬虫与协同过滤的新闻推荐系统 &#x1f947;学长这里给一个题目综合评分(每项满分5分) 难度系数&#xff1a;3分工作量&#xff1a;3分创新点&#xff1a;4分 该项目较为新颖&…...

如何使用Kali Linux进行密码破解?

今天我们探讨Kali Linux的应用&#xff0c;重点是如何使用它来进行密码破解。密码破解是渗透测试中常见的任务&#xff0c;Kali Linux为我们提供了强大的工具来帮助完成这项任务。 1. 密码破解简介 密码破解是一种渗透测试活动&#xff0c;旨在通过不同的方法和工具来破解密码…...

【Freertos基础教程】任务管理之基本使用

文章目录 前言一、freertos任务管理是什么&#xff1f;二、任务管理涉及到的一些概念1.任务状态2.优先级3.栈(Stack)4.事件驱动5.协助式调度(Co-operative Scheduling) 二、任务的基本操作1.创建任务什么是任务 2.创建任务3.任务的删除4.任务的调度3.简单示例 总结 前言 本fre…...

VMware安装BC-linux-eluer 21.10,配置网络

参考配置&#xff1a;https://hiworld.blog.csdn.net/article/details/121608950 /etc/sysconfig/network-scripts/ifcfg-ens33 配置内容如下&#xff1a; TYPEEthernet PROXY_METHODnone BROWSER_ONLYno BOOTPROTOstatic DEFROUTEyes IPV4_FAILURE_FATALno IPV6INITyes IPV6_…...

2023最新Windows编译ffmpeg详细教程,附msys2详细安装配置教程

安装MSYS2 msys2是一款跨平台编译套件&#xff0c;它模拟linux编译环境&#xff0c;支持整合mingw32和mingw64&#xff0c;能很方便的在windows上对一些开源的linux工程进行编译运行。 类似的跨平台编译套件有&#xff1a;msys&#xff0c;cygwin&#xff0c;mingw 优势&…...

【SpringBoot】87、SpringBoot中集成Redisson实现Redis分布式锁

1、Redisson 介绍 Redisson 是架设在 Redis 基础上的一个 Java 驻内存数据网格(In-Memory Data Grid)。Redisson 在基于 NIO 的 Netty 框架上,充分的利用了 Redis 键值数据库提供的一系列优势,在 Java 实用工具包中常用接口的基础上,为使用者提供了一系列具有分布式特性的…...

宝藏级画图工具-drawio

今天推荐一款非常好用的免费开源画图工具drawio. Drawio即可以下载安装到本地&#xff0c;也可以在线编辑&#xff0c;在线编辑网址为 https://app.diagrams.net/。 本地版下载地址为https://github.com/jgraph/drawio-desktop/releases 1、支持各类图形 Drawio可以非常便捷…...

36_windows环境debug Nginx 源码-使用 VSCode 和WSL

文章目录 配置 WSL编译 NginxVSCode 安装插件launch.json配置 WSL sudo apt-get -y install gcc cmake sudo apt-get -y install pcre sudo apt-get -y install libpcre3 libpcre3-dev sudo apt-get...