当前位置:首页 > 建站教程 > 正文内容

图片伸缩展示代码(html图片拉伸代码)

建站教程1个月前 (11-14)59

今天我们来学习 Python 中的 lambda 函数,并探讨使用它的优点和局限性

Let's do it!

什么是 Python 中的 Lambda 函数

lambda 函数是一个匿名函数(即,没有名称定义),它可以接受任意数量的参数,但与普通函数不同,它只计算并返回一个表达式

Python 中的 lambda 函数使用以下语法表达:

lambda 参数:表达式

lambda 函数包括三个元素:

关键字 lambda:与普通函数中 def 类似

参数:支持传递位置和关键字参数,与普通函数一样

正文:处理定参数的表达式

关键字 lambda:与普通函数中 def 类似

参数:支持传递位置和关键字参数,与普通函数一样

正文:处理定参数的表达式

需要注意的是,普通函数不同,这里不需要用括号将 lambda 函数的参数括起来,如果 lambda 函数有两个或更多参数,我们用逗号列出它们

我们使用 lambda 函数只计算一个短表达式(理想情况下,单行)并且只计算一次,这意味着我们以后不会再复用这个函数。通常来说我们会将 lambda 函数作为参数传递给高阶函数(接受其他函数作为参数的函数),例如 Python 内置函数,如 filter、map 或 reduce等

Python 中的 Lambda 函数如何工作

让我们看一个简单的 lambda 函数示例:

lambdax: x + 1

Output:

<function __main__.<lambda>(x)>

上面的 lambda 函数接受一个参数,将其递增 1,然后返回结果

它是以下带有 def 和 return 关键字的普通函数的更简单版本:

defincrement_by_one(x):

展开全文

returnx + 1

到目前我们的 lambda 函数 lambda x: x + 1 只创建一个函数对象,不返回任何内容,这是因为我们没有为其参数 x 提供任何值(参数)。让我们先分配一个变量,将它传递给 lambda 函数,看看这次我们得到了什么:

a = 2

print( lambdax: a + 1)

Output:

<function <lambda> at 0x00000250CB0A5820>

我们的 lambda 函数没有像我们预期的那样返回 3,而是返回了函数对象本身及其内存位置,可以看出这不是调用 lambda 函数的正确方法。要将参数传递给 lambda 函数,执行它并返回结果,我们应该使用以下语法:

( lambdax: x + 1)( 2)

Output:

3

虽然我们的 lambda 函数的参数没有用括号括起来,但当我们调用它时,我们会在 lambda 函数的整个构造以及我们传递给它的参数周围添加括号

上面代码中要注意的另一件事是,使用 lambda 函数,我们可以在创建函数后立即执行该函数并接收结果。这就是所谓的立即调用函数执行(或 IIFE)

我们可以创建一个带有多个参数的 lambda 函数,在这种情况下,我们用逗号分隔函数定义中的参数。当我们执行这样一个 lambda 函数时,我们以相同的顺序列出相应的参数,并用逗号分隔它们:

( lambdax, y, z: x + y + z)( 3, 8, 1)

Output:

12

也可以使用 lambda 函数来执行条件操作。下面是一个简单 if-else 函数的 lambda 模拟:

print(( lambdax: x if(x > 10) else10)( 5))

print(( lambdax: x if(x > 10) else10)( 12))

Output:

10

12

如果存在多个条件(if-elif-...-else),我们必须嵌套它们:

( lambdax: x * 10ifx > 10else(x * 5ifx < 5elsex))( 11)

Output:

110

但是上面的写法,又令代码变得难以阅读

在这种情况下,具有 if-elif-...-else 条件集的普通函数将是比 lambda 函数更好的选择。实际上,我们可以通过以下方式编写上面示例中的 lambda 函数:

defcheck_conditions(x):

ifx > 10:

returnx * 10

elifx < 5:

returnx * 5

else:

returnx

check_conditions( 11)

Output:

110

尽管上面的函数比相应的 lambda 函数增加了更多行,但它更容易阅读

我们可以将 lambda 函数分配给一个变量,然后将该变量作为普通函数调用:

increment = lambdax: x + 1

increment( 2)

Output:

3

但是根据 Python 代码的 PEP 8 样式规则,这是一种不好的做法

赋值语句的使用消除了 lambda 表达式相对于显式 def 语句所能提供的唯一好处(即,它可以嵌入到更大的表达式中)

赋值语句的使用消除了 lambda 表达式相对于显式 def 语句所能提供的唯一好处(即,它可以嵌入到更大的表达式中)

因此如果我们确实需要存储一个函数以供进一步使用,我们最好定义一个等效的普通函数,而不是将 lambda 函数分配给变量

Lambda 函数在 Python 中的应用带有 filter 函数的 Lambda

Python 中的 filter 函数需要两个参数:

定义过滤条件的函数

函数在其上运行的可迭代对象

定义过滤条件的函数

函数在其上运行的可迭代对象

运行该函数,我们得到一个过滤器对象:

lst = [ 33, 3, 22, 2, 11, 1]

filter( lambdax: x > 10, lst)

Output:

<filter at 0x250cb090520>

为了从过滤器对象中获取一个新的迭代器,并且原始迭代器中的所有项都满足预定义的条件,我们需要将过滤器对象传递给 Python 标准库的相应函数:list、tuple、set 、frozenset 或 sorted(返回排序列表)

让我们过滤一个数字列表,只选择大于 10 的数字并返回一个按升序排序的列表:

lst = [ 33, 3, 22, 2, 11, 1]

sorted(filter( lambdax: x > 10, lst))

Output:

[11, 22, 33]

我们不必创建与原始对象相同类型的新可迭代对象,此外我们可以将此操作的结果存储在一个变量中:

图片伸缩展示代码(html图片拉伸代码)

lst = [ 33, 3, 22, 2, 11, 1]

tpl = tuple(filter( lambdax: x > 10, lst))

tpl

Output:

(33, 22, 11)

带有 map 函数的 Lambda

我们使用 Python 中的 map 函数对可迭代的每个项目执行特定操作。它的语法与 filter 相同:一个要执行的函数和一个该函数适用的可迭代对象。

map 函数返回一个 map 对象,我们可以通过将该对象传递给相应的 Python 函数来从中获取一个新的迭代:list、tuple、set、frozenset 或 sorted

与 filter 函数一样,我们可以从 map 对象中提取与原始类型不同类型的可迭代对象,并将其分配给变量。

下面是使用 map 函数将列表中的每个项目乘以 10 并将映射值作为分配给变量 tpl 的元组输出的示例:

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

print(map( lambdax: x * 10, lst))

tpl = tuple(map( lambdax: x * 10, lst))

tpl

Output:

<map object at 0x00000250CB0D5F40>

(10, 20, 30, 40, 50)

map 和 filter 函数之间的一个重要区别是第一个函数总是返回与原始函数相同长度的迭代。因此由于 pandas Series 对象也是可迭代的,我们可以在 DataFrame 列上应用 map 函数来创建一个新列:

importpandas aspd

df = pd.DataFrame({ 'col1': [ 1, 2, 3, 4, 5], 'col2': [ 0, 0, 0, 0, 0]})

print(df)

df[ 'col3'] = df[ 'col1'].map( lambdax: x * 10)

df

Output:

col1 col2

0 1 0

1 2 0

2 3 0

3 4 0

4 5 0

col1 col2 col3

0 1 0 10

1 2 0 20

2 3 0 30

3 4 0 40

4 5 0 50

当然要在上述情况下获得相同的结果,也可以使用 apply 函数:

df[ 'col3'] = df[ 'col1'].apply( lambdax: x * 10)

df

Output:

col1 col2 col3

0 1 0 10

1 2 0 20

2 3 0 30

3 4 0 40

4 5 0 50

我们还可以根据某些条件为另一列创建一个新的 DataFrame 列,对于下面的代码,我们可以互换使用 map 或 apply 函数:

df[ 'col4'] = df[ 'col3'].map( lambdax: 30ifx < 30elsex)

df

Output:

col1 col2 col3 col4

0 1 0 10 30

1 2 0 20 30

2 3 0 30 30

3 4 0 40 40

4 5 0 50 50

带有 reduce 函数的 Lambda

reduce 函数与 functools Python 模块相关,它的工作方式如下:

对可迭代对象的前两项进行操作并保存结果

对保存的结果和可迭代的下一项进行操作

以这种方式在值对上进行,直到所有项目使用可迭代的

对可迭代对象的前两项进行操作并保存结果

对保存的结果和可迭代的下一项进行操作

以这种方式在值对上进行,直到所有项目使用可迭代的

该函数与前两个函数具有相同的两个参数:一个函数和一个可迭代对象。但是与前面的函数不同的是,这个函数不需要传递给任何其他函数,直接返回结果标量值:

fromfunctools importreduce

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

reduce( lambdax, y: x + y, lst)

Output:

15

上面的代码展示了我们使用 reduce 函数计算列表总和时的作用

需要注意的是,reduce 函数总是需要一个带有两个参数的 lambda 函数,而且我们必须首先从 functools Python 模块中导入它

Python 中 Lambda 函数的优缺点优点

它是评估单个表达式的理想选择,应该只评估一次

它可以在定义后立即调用

与相应的普通语法相比,它的语法更紧凑

它可以作为参数传递给高阶函数,例如 filter、map 和 reduce

它是评估单个表达式的理想选择,应该只评估一次

它可以在定义后立即调用

与相应的普通语法相比,它的语法更紧凑

它可以作为参数传递给高阶函数,例如 filter、map 和 reduce

它不能执行多个表达式

它很容易变得麻烦,可读性差,例如当它包括一个 if-elif-...-else 循环

它不能包含任何变量赋值(例如,lambda x: x=0 将抛出一个语法错误)

我们不能为 lambda 函数提供文档字符串

它不能执行多个表达式

它很容易变得麻烦,可读性差,例如当它包括一个 if-elif-...-else 循环

它不能包含任何变量赋值(例如,lambda x: x=0 将抛出一个语法错误)

我们不能为 lambda 函数提供文档字符串

总而言之,我们已经详细讨论了在 Python 中定义和使用 lambda 函数的许多方面:

lambda 函数与普通 Python 函数有何不同

Python 中 lambda 函数的语法和剖析

何时使用 lambda 函数

lambda 函数的工作原理

如何调用 lambda 函数

调用函数执行(IIFE)的定义

如何使用 lambda 函数执行条件操作,如何嵌套多个条件,以及为什么我们应该避免它

为什么我们应该避免将 lambda 函数分配给变量

如何将 lambda 函数与 filter 函数一起使用

如何将 lambda 函数与 map 函数一起使用

我们如何在 pandas DataFrame 中使用

带有传递给它的 lambda 函数的 map 函数 - 以及在这种情况下使用的替代功能

如何将 lambda 函数与 reduce 函数一起使用

在普通 Python 上使用 lambda 函数的优缺点

lambda 函数与普通 Python 函数有何不同

Python 中 lambda 函数的语法和剖析

何时使用 lambda 函数

lambda 函数的工作原理

如何调用 lambda 函数

调用函数执行(IIFE)的定义

如何使用 lambda 函数执行条件操作,如何嵌套多个条件,以及为什么我们应该避免它

为什么我们应该避免将 lambda 函数分配给变量

如何将 lambda 函数与 filter 函数一起使用

如何将 lambda 函数与 map 函数一起使用

我们如何在 pandas DataFrame 中使用

带有传递给它的 lambda 函数的 map 函数 - 以及在这种情况下使用的替代功能

如何将 lambda 函数与 reduce 函数一起使用

在普通 Python 上使用 lambda 函数的优缺点

希望今天的讨论可以使 Python 中看似令人生畏的 lambda 函数概念更清晰、更易于应用,更希望小伙伴们能够喜欢,喜欢就点个 赞吧!

入门: 最全的零基础学Python的问题 | 零基础学了8个月的Python |实战项目 | 学Python就是这条捷径

干货:爬取豆瓣短评,电影《后来的我们》 | 38年NBA最佳球员分析 |从万众期待到口碑扑街!唐探3令人失望 | 笑看新倚天屠龙记 | 灯谜答题王 | 用Python做个海量小姐姐素描图 | 碟中谍这么火,我用机器学习做个迷你推荐系统电影

趣味:弹球游戏 | 九宫格 | 漂亮的花 | 两百行Python《天天酷跑》游戏!

AI:会做诗的机器人 | 给图片上色 | 预测收入 | 碟中谍这么火,我用机器学习做个迷你推荐系统电影

小工具: Pdf转Word,轻松搞定表格和水印! | 一键把html网页保存为pdf! |再见PDF提取收费! | 用90行代码打造最强PDF转换器,word、PPT、excel、markdown、html一键转换 | 制作一款钉钉低价机票提示器! |60行代码做了一个语音壁纸切换器天天看小姐姐! |

年度爆款文案

1). 卧槽!Pdf转Word用Python轻松搞定 !

2).学Python真香!我用100行代码做了个网站,帮人PS旅行图片,赚个鸡腿吃

3).首播过亿,火爆全网,我分析了《乘风破浪的姐姐》,发现了这些秘密

4). 80行代码!用Python做一个哆来A梦分身

5).你必须掌握的20个python代码,短小精悍,用处无穷

6). 30个Python奇淫技巧集

7). 我总结的80页《菜鸟学Python精选干货.pdf》,都是干货

8). 再见Python!我要学Go了!2500字深度分析 !

9).发现一个舔狗福利!这个Python爬虫神器太爽了,自动下载妹子图片

扫描二维码推送至手机访问。

版权声明:本文由我的模板布,如需转载请注明出处。


本文链接:http://390c.top/post/70114.html

分享给朋友:

“图片伸缩展示代码(html图片拉伸代码)” 的相关文章

房产达人最新版(房产达人最新版本无限金币)

房产达人最新版(房产达人最新版本无限金币)

本篇文章给大家谈谈房产达人最新版,以及房产达人最新版本无限金币对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。 本文目录一览: 1、房产达人手机版不能换房子么 2、房产达人手机版哪个房子有地...

学校特色亮点简介300(学校特色亮点简介300字左右)

学校特色亮点简介300(学校特色亮点简介300字左右)

今天给各位分享学校特色亮点简介300的知识,其中也会对学校特色亮点简介300字左右进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、特色学校具有哪些特征 2...

中国铁路人才招聘网(中国铁路人才招聘网简历怎么修改)

中国铁路人才招聘网(中国铁路人才招聘网简历怎么修改)

今天给各位分享中国铁路人才招聘网的知识,其中也会对中国铁路人才招聘网简历怎么修改进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、中国铁路人才招聘报名入口...

学校有行政处罚权吗(学校有权行政处分吗)

学校有行政处罚权吗(学校有权行政处分吗)

今天给各位分享学校有行政处罚权吗的知识,其中也会对学校有权行政处分吗进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、学校对外来人员有能力罚款吗 2、学生违...

2022年最新装修效果图(2020年最新装修效果图)

2022年最新装修效果图(2020年最新装修效果图)

本篇文章给大家谈谈2022年最新装修效果图,以及2020年最新装修效果图对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。 本文目录一览: 1、别墅电视背景墙装修报价多少钱?效果图有吗?要2022...

房产中介管理系统软件排名(房产中介软件排行)

房产中介管理系统软件排名(房产中介软件排行)

今天给各位分享房产中介管理系统软件排名的知识,其中也会对房产中介软件排行进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、目前排名靠前的房产中介管理软件有哪几个...