Python's five points to fix the scope
1. Block-level scope
Think about it, will there be any output when running the following program at this time? Will the execution be successful?
#块级作用域 if 1 == 1: name = "lzl" print(name) for i in range(10): age = i print(age)
Let’s take a look at the execution results first
C:/Users/L/PycharmProjects/s14/preview/Day8/作用域/main.py lzl 9 Process finished with exit code 0
The code is executed successfully and there is no problem; in Java/C#, executing the above code will prompt that name and age are not defined, but in Python it can be executed successfully. This is because in Python There is no block-level scope in the code block. The variables in the code block can be called externally, so they can run successfully;
2. Local scope
Looking back at the knowledge learned before, when we learn functions, functions are Separate scope, there is no block-level scope in Python, but there is local scope; look at the following code
#局部作用域 def func(): name = "lzl" print(name)
Run this code and think about whether there will be any output?
Traceback (most recent call last): File "C:/Users/L/PycharmProjects/s14/preview/Day8/作用域/main.py", line 23, in <module> print(name) NameError: name 'name' is not defined
Running error, I believe everyone can understand this. The name variable only takes effect inside the func() function, so it cannot be called globally. Make a simple adjustment to the above code and see what the result is?
#局部作用域 def func(): name = "lzl" func() #执行函数 print(name)
Added a line of code to the previous code. Before the variable name is printed, a function is executed. Will the printing change at this time?
Traceback (most recent call last): File "C:/Users/L/PycharmProjects/s14/preview/Day8/作用域/main.py", line 23, in <module> print(name) NameError: name 'name' is not defined
Execution still reports an error, let’s go back to the sentence just now: even if the function is executed, the scope of name is only inside the function, and it still cannot be called from outside; remember the first two knowledge points, and start next Enlarging the trick
3. Scope chain
Adjust the function and see what the execution result of the following code is?
#作用域链 name = "lzl" def f1(): name = "Eric" def f2(): name = "Snor" print(name) f2() f1()
Having studied functions, you must know that f1() will output Snor after execution. Let’s remember a concept first. There is a scope chain in Python. Variables will be found from the inside to the outside. First go to your own scope to find it yourself. I didn’t go to the superiors to look for it until I couldn’t find it and reported an error
4. Ultimate version scope
Okay, enough foreshadowing, the ultimate version is here~~
#终极版作用域 name = "lzl" def f1(): print(name) def f2(): name = "eric" f1()
f2()
Think about the last f2 () Does the execution result print "lzl" or "eric"? Remember your answer. Instead of posting the answer now, take a look at the following code:
#终极版作用域 name = "lzl" def f1(): print(name) def f2(): name = "eric" return f1 ret = f2() ret() #输出:lzl
The execution result is "lzl". Analyze the above code. The execution result of f2() is the memory address of function f1. That is, ret=f1; executing ret() is equivalent to executing f1(). When executing f1(), it has nothing to do with f2(). name="lzl" and f1() are in the same scope chain. If there are no variables inside the function, it will Look outside, so the value of the variable name is "lzl" at this time; if you understand this, then you also know the answer to the ultimate code that the answer was not given just now
#终极版作用域 name = "lzl" def f1(): print(name) def f2(): name = "eric" f1() f2()
# Output: lzl
Yes, output It is "lzl". Remember that before the function is executed, the scope has been formed and the scope chain has also been generated
5. Sina interview question
li = [lambda :x for x in range(10)]
Determine the type of li? What type are the elements in li?
print(type(li)) print(type(li[0])) # <class 'list'> # <class 'function'>
You can see that li is a list type and the elements in the list are functions. Then print the return value of the first element in the list. What is the return value at this time?
#lambada interview question
li = [lambda :x for x in range(10)] res = li[0]() print(res)
#Output: 9
liThe return value of the first function is 9, not 0. Remember: the internal code will not be executed before the function is executed; you can practice the code in the blog by yourself Practice and deepen your impression

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

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



PHP and Python have their own advantages and disadvantages, and the choice depends on project needs and personal preferences. 1.PHP is suitable for rapid development and maintenance of large-scale web applications. 2. Python dominates the field of data science and machine learning.

Enable PyTorch GPU acceleration on CentOS system requires the installation of CUDA, cuDNN and GPU versions of PyTorch. The following steps will guide you through the process: CUDA and cuDNN installation determine CUDA version compatibility: Use the nvidia-smi command to view the CUDA version supported by your NVIDIA graphics card. For example, your MX450 graphics card may support CUDA11.1 or higher. Download and install CUDAToolkit: Visit the official website of NVIDIACUDAToolkit and download and install the corresponding version according to the highest CUDA version supported by your graphics card. Install cuDNN library:

Python and JavaScript have their own advantages and disadvantages in terms of community, libraries and resources. 1) The Python community is friendly and suitable for beginners, but the front-end development resources are not as rich as JavaScript. 2) Python is powerful in data science and machine learning libraries, while JavaScript is better in front-end development libraries and frameworks. 3) Both have rich learning resources, but Python is suitable for starting with official documents, while JavaScript is better with MDNWebDocs. The choice should be based on project needs and personal interests.

Docker uses Linux kernel features to provide an efficient and isolated application running environment. Its working principle is as follows: 1. The mirror is used as a read-only template, which contains everything you need to run the application; 2. The Union File System (UnionFS) stacks multiple file systems, only storing the differences, saving space and speeding up; 3. The daemon manages the mirrors and containers, and the client uses them for interaction; 4. Namespaces and cgroups implement container isolation and resource limitations; 5. Multiple network modes support container interconnection. Only by understanding these core concepts can you better utilize Docker.

PyTorch distributed training on CentOS system requires the following steps: PyTorch installation: The premise is that Python and pip are installed in CentOS system. Depending on your CUDA version, get the appropriate installation command from the PyTorch official website. For CPU-only training, you can use the following command: pipinstalltorchtorchvisiontorchaudio If you need GPU support, make sure that the corresponding version of CUDA and cuDNN are installed and use the corresponding PyTorch version for installation. Distributed environment configuration: Distributed training usually requires multiple machines or single-machine multiple GPUs. Place

When installing PyTorch on CentOS system, you need to carefully select the appropriate version and consider the following key factors: 1. System environment compatibility: Operating system: It is recommended to use CentOS7 or higher. CUDA and cuDNN:PyTorch version and CUDA version are closely related. For example, PyTorch1.9.0 requires CUDA11.1, while PyTorch2.0.1 requires CUDA11.3. The cuDNN version must also match the CUDA version. Before selecting the PyTorch version, be sure to confirm that compatible CUDA and cuDNN versions have been installed. Python version: PyTorch official branch

Python excels in automation, scripting, and task management. 1) Automation: File backup is realized through standard libraries such as os and shutil. 2) Script writing: Use the psutil library to monitor system resources. 3) Task management: Use the schedule library to schedule tasks. Python's ease of use and rich library support makes it the preferred tool in these areas.

Updating PyTorch to the latest version on CentOS can follow the following steps: Method 1: Updating pip with pip: First make sure your pip is the latest version, because older versions of pip may not be able to properly install the latest version of PyTorch. pipinstall--upgradepip uninstalls old version of PyTorch (if installed): pipuninstalltorchtorchvisiontorchaudio installation latest
