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

6 python函数

函数

在实现某个功能对应的代码的时候,如果将实现功能对应的函数放到函数中,那么下一次再需要这个功能的时候,就可以不用再写这个功能对应的代码,直接调用这个功能对应的函数。

1.什么是函数

函数就是实现某一特点功能的代码的封装 - 函数就把实现某一功能的代码打成一个包,以后再需要这个功能的时候,直接使用函数就行了。

1) 函数分类

a.系统函数(已经造好的机器):由系统创建好函数,只需要在需要他们提供的功能的时候去调用它,例如:print、input、max、type等

b.自定义函数(自己造机器):由程序员自己创建的函数

2.定义函数(创建函数)

1) 语法:

def 函数名(形参列表):
函数说明文档
函数体

2) 说明:

a.def - 关键字;固定写法
b.函数名 - 程序员自己;
两个要求:是标识符、不是关键字
三个规范:见名知义(看到函数名大概知道这个函数的功能)、不使用系统函数名、类名或者模块名、
所有字母都小写,多个单词用下划线隔开
c.() - 固定写法
d.形参列表 - 以’变量名1,变量名2,变量名3,…'的形式存在,这儿的每一个变量就是一个形参;
形参的个数可以是任意多个:0个、1个、2个 …
形参可以将函数外部的数据传递到函数里面

e.函数说明文档 - 本质就是一个多行注释

f.函数体 - 函数体就是好def保持一个缩进的一条或者多条语句(至少一条)
逻辑上,函数体就是实现函数功能的代码

3) 初学者定义函数的步骤

第一步:确定函数功能
第二步:确定函数名
第三步:确定形参(看实现函数的功能需不需要额外的数据,需要几个)
第四步:通过函数体实现函数功能(这个时候直接将形参作为对应的数据使用)
第五步:确定函数返回值
第六步:写函数说明文档

# 案例:定义一个函数求任意两个数的和
def sum_2(num1, num2):print(num1 + num2)
num1 = 33
num2 = 78
sum_2(num1, num2)# 案例:统计一个字符串中中文的个数
def count_chinese(string):"""(功能说明区)统计一个字符串中中文的个数:param string: (参数说明)需要统计的字符串:return: (返回值说明)None"""count = 0for x in string:if '\u4e00' <= x <= '\u9fa5':count += 1print(count)
count_chinese('国际化后即可ghjh')# 案例:提取两个字符串中公共字符
def common_character(string1, string2):for x in string1:if x in string2:print(x, end='')
common_character('fgjyuiy', 'fhgj')
print()# 案例:求10!
def factorial(num):sum = 1for x in range(1, num + 1):sum *= xprint(sum)
factorial(10)

3.调用函数

1)语法:

函数名(实参列表)

2)说明:

函数名 - 必须是已经定义好的函数名

​ (需要哪个函数功能就调用哪个函数,就写哪个函数的函数名)

() - 固定写法

实参列表 - 实参就是通过形参从函数外部传递到函数内部的数据

​ 以‘数据1,数据2,数据3…的形式存在,这儿的每个数据就一个实参,实参的个数由形参的个数决定’

重要结论:定义函数的时候就执行函数体,调用函数的时候才会执行,调用多少次,函数体就执行多少次。

调用过程:每次调用函数的时候:

1)回到函数定义的位置

2)传参(用实参给形参赋值)

3)执行函数体

4)确认返回值

5)回到函数调用的位置接着往后执行

4.参数

1.位置参数和关键词参数

根据调用函数的时候实参提供方式的不同,可以将实参分为位置参数和关键字参数

注意: a.如果位置参数和关键字参数一起使用,那么位置参数必须在关键字参数的前面

b.不管以什么样的方式传参,必须保证每个参数都有值,并且每个参数只有一个值

1)位置参数
  • 直接将多个数据用逗号隔开,让实参和形参从位置上一一对应
2)关键字参数
  • 以‘形参名=实参名1,形参名2=实参名2,…’形式存在的参数
# 位置参数
func1(10, 20, 30)
func1(20, 10, 30)# 关键词参数
func1(a=10, b=20, c=30)
func1(b=20, a=10, c=30)# 位置参数和关键字参数一起用
func1(10, b=20, c=30)
# func1(a=10,20,c=30)  会报错,位置参数必须在关键字参数的前面
# func1(20,a=10,c=30)  会报错,a赋值了多个值

2.参数默认值

1)定义函数的时候可以以‘形参名=值’的方式给形参赋默认值,有默认值的参数在调用函数的时候可以不用传参。

def func2(a=1, b=2, c=3):print(f'a:{a},b:{b},c:{c}')func2()  # a:1,b:2,c:3
func2(10)  # a:10,b:2,c:3
func2(10, 20)  # a:10,b:20,c:3
func2(10, 20, 30)  # a:10,b:20,c:30
# 如果要跳过前面有默认值的参数,直接给后面的参数传参,必须使用关键字参数
func2(c=30)  # a:1,b:2,c:30
func2(b=20)  # a:1,b:20,c:3

2)定义函数的时候可以有的参数有默认值,有的参数没有默认值,但是没有默认值的参数必须在有默认值参数的前面

def func3(a, b=2, c=3):
# def func4(a=1,b,c=3) 会报错,没有默认值的参数必须放在有默认值的参数的前面print(f'a:{a},b:{b},c:{c}')

3.参数类型说明

定义函数的时候可以对参数类型进行说明:

1)没有默认值的参数:形参名:类型名

2)有默认值的参数:默认值的数据类型就是参数类型

def func7(str1: str, list1: list, str2=''):print(str1.isdigit())print(list1[0])print(str2[0])

5.返回值

1.什么是返回值

返回值就是从函数内部传递到函数外部的数据。

定义函数的时候,需不需要添加返回值的建议:看实现函数的功能有没有产生新的数据,如果有新的数据,就将新的数据作为返回值返回。

2.怎么确定函数返回值

- 怎么将一个数据作为函数的返回值返回

返回值就是return关键字后面的表达式的值(函数内部产生的数据,如果不用返回值返回是无法在函数外部使用)

return 数据

def sum_2(num1, num2):result = num1 + num2return resultsum_2(10, 20)
print(sum_2(10,20))

3.怎么使用函数返回值

函数调用表达式的值就是函数的返回值(Python中每个函数的函数调用都是有结果的,这个结果就是这个函数在调用的时候得到的返回值)

函数调用表达式 - 调用函数的语句

注意:每次调用函数的时候,会执行函数体

def func1(num=1):print(num)def sum_2(num1, num2):result = num1 + num2return resultresult1 = sum([10, 20, 30])
print(f'result1:{result1}')
result2 = sum_2(10, 20)
print(f'result2:{result2}')
result3 = func1()
print(f'reslut3:{result3}')
# 删除指定数字列表中所有的负数
# 方法一:创建新的列表,储存返回值
def del_minus(nums: list):new_nums = []for x in nums:if x >= 0:new_nums.append(x)return new_numslist1 = [10, -10, 26, -78, 6]
result = del_minus(list1)
print(result)  # [10, 26, 6]# 直接删除原列表元素,不需要返回值
def del_minus2(nums: list):for x in nums[:]:if x <= 0:nums.remove(x)list1 = [10, -10, 26, -78, 6]
del_minus2(list1)
print(list1)  # [10, 26, 6]

4. return的作用

注意:return只能在函数体中使用

1)将数据作为函数的返回值返回
2)结束函数(执行函数体的时候如果遇到return,函数直接结束)
def func3(n):for x in range(1, n):if n % 3 == 0:return xprint(f'x:{x}')print(func3(5))
#x:1
#x:2
#x:3
#x:4
#None

6.变量作用域

变量定义完成后的作用范围

根据变量作用域的不同,可以将变量分为全局变量和局部变量

1)全局变量

Python中没有定义在函数和类的变量默认都是全局变量

作用域:从定义开始到程序结束

2)局部变量

Python定义在函数中的变量

作用域:从定义到函数结束

3)全局变量和局部变量的存储原理

1)全局变量默认保存在全局栈区间,全局栈区间会在程序结束后自动释放。

2)调用函数的时候系统会自动为这个函数创建一个临时栈区间,用来保存函数中产生的数据(局部变量就是保存在函数对应的临时栈区间中的),函数对应的临时栈区间会在函数调用结束的时候自动释放

3)在函数中可以通过关键字 global修改局部变量的保存方式

name = '小明'
def func1():global num1  #在函数内部定义全局变量用globalnum1 = 10global name  #在函数中,用global改变全局变量的值name = '小花'func1()
print(num1)
print(name)

7.匿名函数(lambda)

  • 没有名字的函数

    函数名 = lambda 形参列表:返回值

相当于:

​ def 函数名(形参列表):

​ return 返回值

注意:

​ 1.匿名函数的形参至少一个

​ 2.匿名函数的调用和普通函数一样

​ 3.无默认值的类型说明在匿名函数中不能用

# 案例:定义一个匿名函数,求任意两个数的和
sum_1 = lambda a, b: a + b
print(sum_1(1, 2))
print(sum_1(a=1, b=2))sum_2 = lambda a=1, b=2: a + b
print(sum_2())# 练习:定义一个匿名函数,判断指定的年是否是闰年
is_leap_year = lambda year: year % 4 == 0 and year % 100 != 0 or year % 400 == 0
print(is_leap_year(2000))
print(is_leap_year(2001))

8.实参高阶函数

函数的参数是函数的函数就是实参高阶函数

给参数是函数的参数传参:a.使用普通函数函数名;b.使用匿名函数

重点:掌握系统或者第三方库提供的实参高阶函数的用法

常见的实参高阶:max、min、sorted、列表.sort、map、reduce
def func5(x):print(x.split('+'))func5('abc')
print('---------------------------------------华丽的分割线------------------------------------')# func6就是一个实参高阶函数
def func6(x):# x = tx()     # t()def t():print('t函数')func6(t)
print('---------------------------------------华丽的分割线------------------------------------')# func7是实参高阶函数
def func7(x):# x = t2# x = lambda n1, n2: n1 + n2print(x(10, 20) + 30)# print(t2(10, 20) + 30)  print(200 + 30)# print(30 + 30)
def t2(n1, n2):# n1 = 10, n2 = 20return n1 * n2      # return 200func7(t2)
func7(lambda n1, n2: n1 + n2)

max、min、sorted、列表.sort

1. max(序列)

直接比较序列中元素的大小求最大值

max(序列, key=函数) - 按照函数制定的规则比较序列中元素的大小获取最大值
函数的要求:
a. 有且只有一个参数(这个参数代表序列中的每个元素)
b. 有一个返回值(返回值就是比较对象)

nums = [83, 67, 19, 22, 80, 77, 93]
print(max(nums))# 案例:求个位数最大的元素
nums = [83, 67, 19, 22, 80, 77, 93]
result = max(nums, key=lambda item: item % 10)
print(result)       # 19# 案例:求nums中绝对值最大的元素
nums = [8, -283, 89, 100, 82, -34]
result = max(nums, key=lambda item: item ** 2)
print(result)       # -283# 案例:求students中分数最高的学生
students = [{'name': 'stu1', 'age': 18, 'score': 90},{'name': 'stu2', 'age': 22, 'score': 98},{'name': 'stu3', 'age': 25, 'score': 78},{'name': 'stu4', 'age': 19, 'score': 81},{'name': 'stu5', 'age': 20, 'score': 92}
]
result = max(students, key=lambda item: item['score'])
print(result)# 案例:按照分数的高度对学生从大到小排序
result = sorted(students, key=lambda item: item['score'], reverse=True)
print(result)# 练习1:求list1中长度最长的字符串
list1 = ['你好', 'hello', 'how are you', 'thank you! and you?', '好好学习,天天向上']
result = max(list1, key=lambda item: len(item))
print(result)# 练习2:求nums中十位数最小的元素
nums = [92, 129, 37, 99, 150, 501]
result = min(nums, key=lambda item: item // 10 % 10)
print(result)# 练习3:将所有的学生按照年龄值从小到大排序
students = [{'name': 'stu1', 'age': 18, 'score': 90},{'name': 'stu2', 'age': 22, 'score': 98},{'name': 'stu3', 'age': 25, 'score': 78},{'name': 'stu4', 'age': 19, 'score': 81},{'name': 'stu5', 'age': 20, 'score': 92}
]
students.sort(key=lambda item: item['age'])
print(students)# 练习4:求nums中各个位之和最大的元素
nums = [123, 78, 90, 201, 192, 330]
# 123  -> 1 + 2 + 3
# '123' -> '1'、'2'、'3', [1, 2, 3]# 方法1:
result = max(nums, key=lambda item: sum([int(x) for x in str(item)]))
print(result)# 方法2:
# 123 -> eval('1+2+3')
# 123 -> '123'  -> '+'.join('123') -> '1+2+3'
result = max(nums, key=lambda item: eval('+'.join(str(item))))
print(result)# 方法3:
def t(item):sum1 = 0for x in str(item):sum1 += int(x)return sum1result = max(nums, key=t)
print(result)

2. map

  • 基于原序列中的元素创建一个新的序列

1)map(函数, 序列) - 通过函数描述的规则基于序列中的元素创建一个新的序列
函数要求:
a. 有且只有一个参数(代表后面的这个序列中每个元素)
b. 有一个返回值(返回值就是新序列中元素)

2)map(函数, 序列1, 序列2)
函数要求:
a. 有且只有2个参数(分别代表后面的两个序列中每个元素)
b. 有一个返回值(返回值就是新序列中元素)

3)map(函数, 序列1, 序列2, 序列3,…)

# 案例1:将nums中所有的元素乘以10
nums = [19, 870, 34, 61, 78]
result = map(lambda item: item*10, nums)
print(list(result))     # [190, 8700, 340, 610, 780]# 案例2:获取nums中所有元素的个位数
result = map(lambda item: item % 10, nums)
print(list(result))     # [9, 0, 4, 1, 8]# 案例2:将nums1和nums2中相同位置上的元素相乘,得到一个新的序列
nums1 = [10, 20, 30, 10]
nums2 = [23, 30, 20, 55]
result = map(lambda i1, i2: i1 * i2, nums1, nums2)
print(list(result))     # # [230, 600, 600, 550]# 练习1:获取names中每个人的姓
names = ['何晓东', '张三', '李四', '王五', '王二', '赵六']
result = map(lambda item: item[0], names)
print(list(result))# 练习2:
students = [{'name': 'stu1', 'age': 18, 'score': 90},{'name': 'stu2', 'age': 22, 'score': 98},{'name': 'stu3', 'age': 25, 'score': 78},{'name': 'stu4', 'age': 19, 'score': 81},{'name': 'stu5', 'age': 20, 'score': 92}
]
subjects = ['电子信息', '金融数学', '园林设计', '经济', '计算机软件']# ['电子信息-stu1', '金融数学-stu2',....]
result = map(lambda i1, i2: f'{i2}-{i1["name"]}', students, subjects)
print(list(result))

3. reduce

  • 将序列中元素合并成一个数据(基于原序列中所有的元素得到一个数据)

reduce(函数, 序列, 初始值) - 按照函数制定的规则将序列中的元素合并成一个数据
函数的要求:
a. 有且只有两个参数(第一个参数指向初始值,第二个参数代表序列中的每个元素)
b. 需要一个返回值 (返回值就是合并规则)

初始值: 累积求数值和,初始值是0

累积求数值乘积,初始值是1

字符串合并,初始值是空串(‘’)

from functools import reducenums = [12, 301, 40, 55, 112]
# 案例1:12 + 301 + 40 + 55 + 112 的结果
# 0 + 12 + 301 + 40 + ... + 112
result = reduce(lambda x, item: x + item, nums, 0)
print(result)# 案例:12 * 301 * 40 * 55 * 112 的结果
# 1 * 12 * 301 * ... * 112
result = reduce(lambda x, item: x * item, nums, 1)
#x表示初始值,item表示序列中的每一个元素
print(result)# 案例:123014055112  -> '123014055112'
# '' + '12' + '301' + '40' + ... + '112'
# '' + str(12) + str(301) +... + str(112)
result = reduce(lambda x, item: x + str(item), nums, '')
print(result)       # '123014055112'# 练习:2+1+0+5+2
nums = [12, 301, 40, 55, 112]
# 0 + 2 + 1 + 0 + 5 + 2
# 0 + 12 % 10 + 301 % 10 + ... + 112 % 10
result = reduce(lambda x, item: x + item % 10, nums, 0)
print(result)

迭代器

1. 什么是迭代器(iter)

1)迭代器是容器型数据类型(可以遍历,也转换成列表),无法直接提供一个迭代器,只能将其他序列转换成迭代器。

2)特点:
a.打印迭代器的时候无法查看到元素有哪些

​ b.无法通过len获取迭代器中元素的个数

​ c.如果要使用迭代器中的元素必须将元素从迭代器中取出来(取走),取走的元素会从迭代器中永远消失(用一个就少一个)

3)任何数据都可以作为迭代器的元素

1)创建迭代器

i1 = iter('abc')
i2 = iter([10, 20, 30, 40])
i3 = iter((10, 1.23, 'abc', True, [10, 20]))

2)打印迭代器无法查看元素

print(i1)
print(i2)

3)迭代器无法统计个数

# print(len(i1))        # 报错!

2. 获取迭代器中的元素

无论以任何方式获取到了迭代器中的某个元素,那么这个元素一定会从迭代器中消失。

1)获取单个元素:

next(迭代器) - 获取迭代器最前面的元素

2)遍历迭代器

for 变量 in 迭代器:
循环体
print(next(i1))     # 'a'
print(next(i1))     # 'b'
print(next(i1))     # 'c'
# print(next(i1))     # 报错!print(next(i2))     # 10
print(list(i2))     # [20, 30, 40]
# print(next(i2))     # 报错!print('---------------------------------------华丽的分割线------------------------------------')
for x in i3:print(x)print(list(i3))     # []

生成器

1.什么是生成器

1)容器(是一种可以创建多个数据的容器,生成器中保存的是创建数据的方法,而不是数据本身。)

2)特点:

​ a.打印生成器无法查看元素;

​ b.不能通过len统计元素的个数

​ c.如果需要生成器中的数据,必须将数据取出,而且取一个就少一个

2.怎么创建生成器

调用带有yield关键字的函数,就可以得到一个生成器

定义一个函数,函数中写一个yield

def func1():yieldprint('hello')return 100result = func1()
print(f'result:{result}')

3.怎么控制生成器中元素的个数和元素的值

执行创建生成器的函数的函数体是,会遇到几次yield,对应的生成器就可以创建几个数据,每次遇到yield,yield后面的值就是能创建出来的数据。

def func3(n):yield 100if n % 2 == 0:yield 200yield 300gen3 = func3(3)
print('next:',next(gen3))	#next: 100
print('next:',next(gen3))	#next: 300
# print('next:',next(gen3)) #生成器为空了,取不了数
def func3(n):yield 100if n % 2 == 0:yield 200yield 300gen3 = func3(3)
print(gen3) 
#<generator object func3 at 0x000002D9B4192120>
print(list(gen3))
#[100, 300]

相关文章:

6 python函数

函数 在实现某个功能对应的代码的时候&#xff0c;如果将实现功能对应的函数放到函数中&#xff0c;那么下一次再需要这个功能的时候&#xff0c;就可以不用再写这个功能对应的代码&#xff0c;直接调用这个功能对应的函数。 1.什么是函数 函数就是实现某一特点功能的代码的封装…...

7.避免不必要的渲染

目录 1 组件更新机制 2 虚拟DOM配合Diff算法 3 减轻state 4 shouldComponentUpdate() 4.1 基本使用 4.2 使用参数 5 纯组件 5.1 基本使用 5.2 纯组件的比较方法 shallow compere 1 组件更新机制 当父组件重新渲染时&#xff0c;父组件的所有子组件也会重新…...

国产化大趋势下学习linux的必要性

由于国际上的一些国家的制裁和威胁。最近几年国产化大趋势慢慢的兴起&#xff0c;我们国产化硬件的需求越来越大。对国产操作系统的需求也越来越多&#xff0c;那么我们一直用的Windows系统为什么不用了呢&#xff1f;众所周知的原因&#xff0c;不管是最新的Windows11还是正值…...

浅谈虚树

问题引入 你是否遇到过下面这种问题&#xff1a; SDOI2011 消耗战 在一场战争中&#xff0c;战场由 nnn 个岛屿和 n−1n-1n−1 个桥梁组成&#xff0c;保证每两个岛屿间有且仅有一条路径可达。现在&#xff0c;我军已经侦查到敌军的总部在编号为1的岛屿&#xff0c;而且他们已…...

裸机条件下写一个基于时间片轮转的多任务并发程序

目录前言A. 使用RTOSB.裸机多任务并发前言 在学习各种MCU的时候&#xff0c;都是用在main函数里写一个while(1){/* 执行代码 */}&#xff0c;这种方式只能一个函数运行完以后再运行另一个函数。 假设需求控制多个模块&#xff0c;如显示屏幕信息的同时控制电机&#xff0c;还要…...

RK3588 系统定制开关机动画

平台&#xff1a;ITX-3588J, ROC-RK3588S-PC 系统&#xff1a;Android12.0 作者&#xff1a;jpchen & zzz 一. 功能描述 定制自己的开机动画和关机动画 二. 功能实现 1.开启功能 修改device/rockchip/common/BoardConfig.mk文件 BOOT_SHUTDOWN_ANIMATION_RINGINGtrue2.…...

水文-编程命令快查手册

前言 脑子里面记不住一些命令&#xff0c;每次遇到都得查下。我经常在三个实体电脑&#xff0c;windows/uos/ubuntu不同系统上编程。 所以web版本的笔记查看起来方便点。这里报错下。 二级标题 cmake windows在cmake --build的时候&#xff0c;使用–config&#xff0c;指定…...

如何优雅编写测试用例

当你学会了如何设计测试用例之后&#xff0c;接下来便是开始用例的编写。 在设计阶段&#xff0c;更准确的说应该是识别测试点的过程&#xff0c;而编写阶段则是将测试点细化成一条条测试用例的过程&#xff0c;有了比较全的用例场景后&#xff0c;如何让别人更舒服、更方便、…...

[入门必看]数据结构2.3:线性表的链式表示

[入门必看]数据结构2.3&#xff1a;线性表的链式表示第二章 线性表2.3 线性表的链式表示知识总览2.3.1 单链表的定义2.3.2_1 单链表的插入删除2.3.2_2 单链表的查找2.3.2_3 单链表的建立2.3.3 双链表2.3.4 循环链表2.3.5 静态链表2.3.6 顺序表和链表的比较2.3.1 单链表的定义单…...

Golang流媒体实战之二:回源

欢迎访问我的GitHub 这里分类和汇总了欣宸的全部原创(含配套源码)&#xff1a;https://github.com/zq2599/blog_demos 本篇概览 今天的实战是流传输过程中的常见功能&#xff1a;回源如下图&#xff0c;lal(源站)和lal(拉流节点)代表两台电脑&#xff0c;上面都部署了lalVLC在…...

webgl——给场景添加光

文章目录前言光照理论介绍光照效果光源类型反射光颜色向场景中添加光向场景中添加环境光和点光源逐片元光照——更加逼真总结前言 在之前的学习中已经将三维物体添加到了场景中&#xff0c;但是并没有在场景中使用光&#xff0c;照可以使模型更具有立体感&#xff0c;本文主要…...

Vue实战【Vue项目开发时常见的几个错误】

目录&#x1f31f;前言&#x1f31f;安装超时(install timeout)&#x1f31f;can’t not find ‘xxModule’ - 找不到某些依赖或者模块&#x1f31f;data functions should return an object&#x1f31f;给组件内的原生控件添加事件,不生效了&#x1f31f;我在函数内用了this.…...

【多线程】常见的锁策略

✨个人主页&#xff1a;bit me&#x1f447; ✨当前专栏&#xff1a;Java EE初阶&#x1f447; ✨每日一语&#xff1a;老当益壮&#xff0c;宁移白首之心&#xff1b;穷且益坚&#xff0c;不坠青云之志。 目 录&#x1f3f3;️一. 乐观锁 vs 悲观锁&#x1f3f4;二. 普通的互斥…...

如何让虚拟机里的Ubuntu通过连接手机USB数据线上网

目录 一 前言 二 Windows联网方法 三 Ubuntu联网方法 一 前言 最近遇到了这样一个问题&#xff0c;有一台台式机&#xff0c;地插网口无法访问外网&#xff0c;周边也没有无线路由器&#xff0c;要访问外网&#xff0c;该如何做&#xff1f;进一步的&#xff0c;这台台式机…...

windows渗透(sam、system文件导出)

通过本地PC中渗透测试平台Kali对服务器场景Windows进行系统服务及版本扫描渗透测试,并将该操作显示结果中Telnet服务对应的端口号作为FLAG提交;通过本地PC中渗透测试平台Kali对服务器场景Windows进行系统服...

b01lers(php.galf)

目录 前文 正文 前文 <?phpclass A{public $codeNULL;public $argsNULL;public function __construct($code,$argsNULL){$this->code$code;$this->args$args;print_r("2333") ;} public function __invoke($code,$args){echo $code;print_r("执行inv…...

记一次若依后台管理系统渗透

前言 最近客户开始hw前的风险排查&#xff0c;让我们帮他做个渗透测试&#xff0c;只给一个单位名称。通过前期的信息收集&#xff0c;发现了这个站点&#xff1a; 没有验证码&#xff0c;再加上这个图标&#xff0c;吸引了我注意&#xff1a; 从弱口令开始 若依默认口令为ad…...

Mybatis(四):自定义映射resultMap

自定义映射resultMap前言一、处理字段和属性的映射关系问题&#xff1a;方案一&#xff1a;使用别名方案二&#xff1a;在mybatis-config.xml中设置mapUnderscoreToCamelCase方案三&#xff1a;在映射文件中设置redultMap二、多对一映射处理问题&#xff1a;方案一&#xff1a;…...

机器学习---降维算法

知其然知其所以然【写在前面】主成分分析&#xff08;PCA&#xff09;原理部分代码部分可视化部分线性判别分析&#xff08;LDA&#xff09;原理部分代码部分可视化部分独立成分分析&#xff08;ICA&#xff09;原理部分代码部分可视化部分t-SNE降维算法原理部分代码部分可视化…...

【Vue2从入门到精通】详解Vue.js的15种常用指令及其使用场景

文章目录前言1. v-text / {{ expression }}2.v-html3.v-bind4.v-on5. v-model6.v-for7.v-if / v-else-if / v-else9.v-show10.v-cloak11.v-pre12.组件注册指令13.动态组件指令14.自定义指令15.过滤器指令前言 Vue.js 是一款流行的前端框架&#xff0c;它通过指令&#xff08;Di…...

数据库知识总结

数据库知识点总结个人向。 目录第一章 绪论第二章 关系数据库第三章 关系数据库标准语言SQL第四章 数据库安全性第五章 数据库完整性第六章 关系数据理论第七章 数据库设计第十章 数据库恢复技术第十一章 并发控制第一章 绪论 数据(data): 描述事物的符号记录。 数据库(DataB…...

处理数组循环中删除元素导致索引错位情况

就是很多时候我们对一个数组进行操作的时候&#xff0c;在for遍历的过程中删掉了一个元素&#xff0c;那么在删掉那个元素之后的所有元素的索引值都会减少一位&#xff0c;数组长度缩短一位&#xff0c;删完之后&#xff0c;正在进行的循环会继续循环下去&#xff0c;但是循环的…...

快速排序,分治法实际应用(含码源与解析)

&#x1f38a;【数据结构与算法】专题正在持续更新中&#xff0c;各种数据结构的创建原理与运用✨&#xff0c;经典算法的解析✨都在这儿&#xff0c;欢迎大家前往订阅本专题&#xff0c;获取更多详细信息哦&#x1f38f;&#x1f38f;&#x1f38f; &#x1fa94;本系列专栏 -…...

linux入门---操作体统的概念

什么是操作系统 操作系统是一个对软硬件资源进行管理的软件。计算机由一堆硬件组成&#xff0c;这些硬件遵循着冯诺依曼体系结构 在这个硬件的基础上还有一个软件叫做操作系统 操作系统的任务是对硬件进行管理&#xff0c;既然是管理的话操作系统得访问到底层的硬件&#xf…...

《Qt 6 C++开发指南》提供4个版本的示例程序

《Qt 6 C开发指南》包含丰富的示例项目&#xff0c;为了方便读者使用《Qt 6 C开发指南》学习Qt编程&#xff0c;本书提供了4个版本的示例程序。读者可在人民邮电出版社异步社区本书的配套资源&#xff08;如图1&#xff09;里下载这4个版本的示例程序。图1 异步社区本书配套资源…...

chartgpt 告诉我的,loss 函数的各种知识

一、libtorch中常见的损失函数及其使用场景的总结1. CrossEntropyLoss:CrossEntropyLoss&#xff08;交叉熵损失&#xff09;主要用于分类任务。它适用于多分类问题&#xff0c;其中每个样本只属于一个类别&#xff08;互斥&#xff09;。该损失函数将预测概率与真实标签的one-…...

旅行推销员问题的遗传算法中的完整子路线顺序交叉

摘要 旅行商问题&#xff08;TSP&#xff09;是许多著名的组合问题之一。TSP可以解释为很难找到从第一个城市出发&#xff0c;经过所有城市&#xff0c;然后返回起点的最短距离。在标准问题中&#xff0c;TSP通常用于确定新算法的效率。遗传算法是求解TSP问题的一种成功算法。…...

Python实现词频统计

词频统计是自然语言处理的基本任务&#xff0c;针对一段句子、一篇文章或一组文章&#xff0c;统计文章中每个单词出现的次数&#xff0c;在此基础上发现文章的主题词、热词。 1. 单句的词频统计 思路&#xff1a;首先定义一个空字典my_dict&#xff0c;然后遍历文章&#xf…...

微信小程序面试题(day08)

文章目录微信小程序自定义组件的使用&#xff1f;微信小程序事件通道的使用&#xff1f;微信小程序如何使用vant组件库&#xff1f;微信小程序自定义组件父传子子传父&#xff1f;微信小程序自定义组件生命周期有哪些&#xff1f;微信小程序授权登录流程&#xff1f;web-view。…...

最强的Python可视化神器,你有用过么?

数据分析离不开数据可视化&#xff0c;我们最常用的就是Pandas&#xff0c;Matplotlib&#xff0c;Pyecharts当然还有Tableau&#xff0c;看到一篇文章介绍Plotly制图后我也跃跃欲试&#xff0c;查看了相关资料开始尝试用它制图。 1、Plotly Plotly是一款用来做数据分析和可视…...

委托别人做网站侵权了/注册一个域名需要多少钱

软件质量是指软件产品中能满足给定需求的各种特性的综合。这些特性称作质量特性,它包括功能性、可靠性、易使用性、时间经济性、资源经济性、可维护性和可移植性等。具体地说,软件质量是软件与明确叙述的功能和性能需求、文档中明确揩述的开发标准,以及任何专业开发的软件产品都…...

吉林网络推广代运营/优化教程网下载

本文介绍的是如何用 Python 语言实现 12306 自动预定列车票&#xff0c;也就是坊间常说的“抢票”&#xff0c;但个人觉得&#xff0c;这不算是“抢”&#xff0c;只不过是一定程度的自动化。总体设计所谓抢票软件&#xff0c;本质上就是基于浏览器驱动&#xff0c;实现登录、预…...

wordpress 文章目录导航/seo查询 站长工具

server {listen 80;server_name localhost;location /api1/ {proxy_pass http://localhost:8080;}# http://localhost/api1/xxx -> http://localhost:8080/api1/xxx# 如果proxy_pass路径是根路径且后面没有/,而location路径后面有/,则实际生成的请求路径是proxy_pas…...

网页制作动画怎么做/什么是搜索引擎优化seo

一. 简介 MapReduce是一个高性能的批处理分布式计算框架&#xff0c;用于对海量数据进行并行分析和处理。与传统方法相比较&#xff0c;MapReduce更倾向于蛮力去解决问题&#xff0c;通过简单、粗暴、有效的方式去处理海量的数据。通过对数据的输入、拆分与组合&#xff08;核…...

网站建设工具有哪些/app推广在哪里可以接单

[导读&#xff3d;能赚钱的个人开发者很多&#xff0c;但是他们不愿意分享他们的发财之道。对初期个人开发者或者技术宅来说&#xff0c;赚钱只能靠公司的薪水&#xff0c;摆脱不了被压榨的命运。所 以&#xff0c;建立这个公众帐号&#xff0c;是想让更多的新手、刚入这个行业…...

wordpress 编辑器/建个人网站的详细步骤

日期&#xff1a;2004-06-24 作者&#xff1a;chen123 配置要求&#xff1a;IIS&#xff08;win2000 server 自带&#xff09;、Java 2 SDK 1.4.2 (或更高版本)、Tomcat Web Server 连接器、 Tomcat 5.0.24 (或更高版本) 准备 一、Java 2 SDK 1.4.2 (或更高版本)…...