This article brings you relevant knowledge about Python, which mainly organizes related issues about the scope of lambda, as well as related content about closures in Python. Let’s take a look I hope it helps everyone.
【Related recommendations: Python3 video tutorial】
Scope of Python closures and lambda
lambda Writing method
def fun(): for i in range(3): yield lambda x : x * i f0, f1, f2 = fun() print(f0(1), f1(2), f2(3))
Writing method of closure
def fun(): result = [] for i in range(3): def demo(x): return x * i result.append(demo) return result f0, f1, f2 = fun() print(f0(1), f1(2), f2(3))
The results of the above two writing methods are 2, 4, 6. According to the original idea, the results should be 0, 2, 6.
Cause of the problem:
The root of the problem lies in python’s variable search rules, LEGB (local, enclosed, global, bulitin). In the above example, i is in Closure scope (enclosing), and Python's closure is late binding. The value of the variable i used in the closure is found when the internal function is called.
Solution
Change closure scope to local scope
lambda writing method
def fun(): for i in range(3): yield lambda x, i = i: x * i f0, f1, f2 = fun() print(f0(1), f1(2), f2(3))
closure writing method
def fun(): result = [] for i in range(3): def demo(x, i=i): return x * i result.append(demo) return result f0, f1, f2 = fun() print(f0(1), f1(2), f2(3))
The above output result is 0, 2, 6
Another situation:
def fun(): for i in range(3): yield lambda x : x * i f0, f1, f2 = fun() print(f0(1), f1(2), f2(3))
The output result is still 2, 4, 6
Cause of the problem
The generator (or iterator) returned by the fun() method is not actually executed, but is executed every time it is called.
When printing is performed after traversal, the i variable uses the value of the last call. If lambda is regarded as a closure method, the value of variable i is still in the closure scope (no local)
The pitfalls in python (closure and lambda)
Let’s look at a chestnut first
def create(): return [lambda x:i*x for i in range(5)] for i in create(): print(i(2))
Result:
8
8
8
8
8
The return value of the create function is a list, and each element of the list is a function - a function that multiplies the input parameter x by a multiple i. The expected results were 0, 2, 4, 6, 8. But the result was 5 and 8, which was unexpected.
Since lambda is often used when this trap occurs, you may think it is a problem with lambda, but lambda expresses its unwillingness to take the blame. The essence of the problem lies in the attribute search rules in python, LEGB (local, enclosing, global, bulitin). In the above example, i is in the closure scope (enclosing), and Python's closure is late binding. This means that the value of the variable used in the closure is queried when the internal function is called.
The solution is also very simple, that is, change the closure scope to the local scope.
def create(): return [lambda x, i=i:i*x for i in range(5)] for i in create(): print(i(2))
Another way of writing:
def create(): a = [] for i in range(5): def demo(x, i=i): return x*i a.append(demo) return a for i in create(): print(i(2))
The above two ways of writing are the same
Result:
0
2
4
6
8
Another chestnut with a similar problem
The code is very simple: (Statement: python3 Question)
nums = range(2,20) for i in nums: nums = filter(lambda x: x==i or x%i, nums) print(list(nums))
Result:
[2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16 , 17, 18, 19]
Similarly, according to normal logic, the result should be:
[2, 3, 5, 7, 11, 13, 17, 19 ]
Cause of the problem:
- In python3, the filter() function returns an iterator, so it does not actually do any Executed, but executed every time it is called (the value list returned by filter() in python2 does not have this phenomenon)
- When printing is executed after traversal, the function in the loop is now executed, the same as the chestnut above The problem is that the variable i uses the value of the last call. The difference from the above chestnut is that the above chestnut uses the value of the embedded scope, while this chestnut uses the value of the global i
Modify code:
nums = range(2,20) for i in nums: nums = filter(lambda x,i=i: x==i or x%i, nums) print(list(nums))
Result:
[2, 3, 5, 7, 11, 13, 17, 19]
【 Related recommendations: Python3 video tutorial】
The above is the detailed content of Scope analysis of closures and lambdas in Python. For more information, please follow other related articles on the PHP Chinese website!

Python and C each have their own advantages, and the choice should be based on project requirements. 1) Python is suitable for rapid development and data processing due to its concise syntax and dynamic typing. 2)C is suitable for high performance and system programming due to its static typing and manual memory management.

Choosing Python or C depends on project requirements: 1) If you need rapid development, data processing and prototype design, choose Python; 2) If you need high performance, low latency and close hardware control, choose C.

By investing 2 hours of Python learning every day, you can effectively improve your programming skills. 1. Learn new knowledge: read documents or watch tutorials. 2. Practice: Write code and complete exercises. 3. Review: Consolidate the content you have learned. 4. Project practice: Apply what you have learned in actual projects. Such a structured learning plan can help you systematically master Python and achieve career goals.

Methods to learn Python efficiently within two hours include: 1. Review the basic knowledge and ensure that you are familiar with Python installation and basic syntax; 2. Understand the core concepts of Python, such as variables, lists, functions, etc.; 3. Master basic and advanced usage by using examples; 4. Learn common errors and debugging techniques; 5. Apply performance optimization and best practices, such as using list comprehensions and following the PEP8 style guide.

Python is suitable for beginners and data science, and C is suitable for system programming and game development. 1. Python is simple and easy to use, suitable for data science and web development. 2.C provides high performance and control, suitable for game development and system programming. The choice should be based on project needs and personal interests.

Python is more suitable for data science and rapid development, while C is more suitable for high performance and system programming. 1. Python syntax is concise and easy to learn, suitable for data processing and scientific computing. 2.C has complex syntax but excellent performance and is often used in game development and system programming.

It is feasible to invest two hours a day to learn Python. 1. Learn new knowledge: Learn new concepts in one hour, such as lists and dictionaries. 2. Practice and exercises: Use one hour to perform programming exercises, such as writing small programs. Through reasonable planning and perseverance, you can master the core concepts of Python in a short time.

Python is easier to learn and use, while C is more powerful but complex. 1. Python syntax is concise and suitable for beginners. Dynamic typing and automatic memory management make it easy to use, but may cause runtime errors. 2.C provides low-level control and advanced features, suitable for high-performance applications, but has a high learning threshold and requires manual memory and type safety management.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft

Dreamweaver CS6
Visual web development tools

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.