Hướng dẫn what is scope resolving rule in python - quy tắc giải quyết phạm vi trong python là gì

Khái niệm về quy tắc phạm vi cách các biến và tên được tra cứu trong mã của bạn. Nó xác định khả năng hiển thị của một biến trong mã. Phạm vi của một tên hoặc biến phụ thuộc vào vị trí trong mã của bạn nơi bạn tạo biến đó. Khái niệm phạm vi Python thường được trình bày bằng cách sử dụng một quy tắc được gọi là Quy tắc LEGB.scope rules how variables and names are looked up in your code. It determines the visibility of a variable within the code. The scope of a name or variable depends on the place in your code where you create that variable. The Python scope concept is generally presented using a rule known as the LEGB rule.

Các chữ cái trong từ viết tắt của LegB là các phạm vi địa phương, bao quanh, toàn cầu và tích hợp. Điều này tóm tắt không chỉ các cấp độ phạm vi Python mà còn cả chuỗi các bước mà Python theo sau khi giải quyết tên trong một chương trình.Local, Enclosing, Global, and Built-in scopes. This summarizes not only the Python scope levels but also the sequence of steps that Python follows when resolving names in a program.

Trong hướng dẫn này, bạn sẽ học:

  • Phạm vi là gì và cách chúng hoạt động trong Pythonscopes are and how they work in Python
  • Tại sao nó rất quan trọng để biết về phạm vi PythonPython scope
  • Quy tắc LegB là gì và cách Python sử dụng nó để giải quyết tênLEGB rule is and how Python uses it to resolve names
  • Cách sửa đổi hành vi tiêu chuẩn của phạm vi Python bằng cách sử dụng
    >>> square.__code__.co_varnames
    ['base', 'result']
    >>> square.__code__.co_argcount
    1
    >>> square.__code__.co_consts
    [None, 2, 'The square of ', ' is: ']
    >>> square.__code__.co_name
    'square'
    
    3 và
    >>> square.__code__.co_varnames
    ['base', 'result']
    >>> square.__code__.co_argcount
    1
    >>> square.__code__.co_consts
    [None, 2, 'The square of ', ' is: ']
    >>> square.__code__.co_name
    'square'
    
    4standard behavior of Python scope using
    >>> square.__code__.co_varnames
    ['base', 'result']
    >>> square.__code__.co_argcount
    1
    >>> square.__code__.co_consts
    [None, 2, 'The square of ', ' is: ']
    >>> square.__code__.co_name
    'square'
    
    3 and
    >>> square.__code__.co_varnames
    ['base', 'result']
    >>> square.__code__.co_argcount
    1
    >>> square.__code__.co_consts
    [None, 2, 'The square of ', ' is: ']
    >>> square.__code__.co_name
    'square'
    
    4
  • Những công cụ liên quan đến phạm vi mà Python cung cấp và cách bạn có thể sử dụng chúngscope-related tools Python offers and how you can use them

Với kiến ​​thức này trong tay, bạn có thể tận dụng phạm vi Python để viết các chương trình đáng tin cậy và có thể duy trì hơn. Sử dụng phạm vi Python sẽ giúp bạn tránh hoặc giảm thiểu các lỗi liên quan đến va chạm tên cũng như sử dụng xấu các tên toàn cầu trên các chương trình của bạn.

Bạn có thể tận dụng tối đa hướng dẫn này nếu bạn quen thuộc với các khái niệm Python trung gian như các lớp, chức năng, chức năng bên trong, biến, ngoại lệ, toàn diện, chức năng tích hợp và cấu trúc dữ liệu tiêu chuẩn.

Hiểu phạm vi

Trong lập trình, phạm vi của một tên xác định khu vực của một chương trình mà bạn có thể truy cập rõ ràng vào tên đó, chẳng hạn như các biến, hàm, đối tượng, v.v. Một tên sẽ chỉ được hiển thị và có thể truy cập bằng mã trong phạm vi của nó. Một số ngôn ngữ lập trình tận dụng phạm vi để tránh va chạm tên và hành vi không thể đoán trước. Thông thường nhất, bạn sẽ phân biệt hai phạm vi chung:

  1. Phạm vi toàn cầu: Tên mà bạn xác định trong phạm vi này có sẵn cho tất cả các mã của bạn. The names that you define in this scope are available to all your code.

  2. Phạm vi cục bộ: Tên mà bạn xác định trong phạm vi này chỉ có sẵn hoặc hiển thị với mã trong phạm vi. The names that you define in this scope are only available or visible to the code within the scope.

Phạm vi xuất hiện bởi vì các ngôn ngữ lập trình sớm [như cơ bản] chỉ có tên toàn cầu. Với loại tên này, bất kỳ phần nào của chương trình đều có thể sửa đổi bất kỳ biến nào bất cứ lúc nào, vì vậy việc duy trì và gỡ lỗi các chương trình lớn đều có thể trở thành một cơn ác mộng thực sự. Để làm việc với các tên toàn cầu, bạn cần phải ghi nhớ tất cả các mã đồng thời để biết giá trị của một tên nhất định là gì bất cứ lúc nào. Đây là một tác dụng phụ quan trọng của việc không có phạm vi.global names. With this kind of name, any part of the program could modify any variable at any time, so maintaining and debugging large programs could become a real nightmare. To work with global names, you’d need to keep all the code in mind at the same time to know what the value of a given name is at any time. This was an important side-effect of not having scopes.

Một số ngôn ngữ như Python sử dụng phạm vi để tránh loại vấn đề này. Khi bạn sử dụng một ngôn ngữ thực hiện phạm vi, thì không có cách nào để bạn truy cập tất cả các biến trong một chương trình tại tất cả các vị trí trong chương trình đó. Trong trường hợp này, khả năng truy cập một tên nhất định của bạn sẽ phụ thuộc vào nơi bạn đã xác định tên đó.scope to avoid this kind of problem. When you use a language that implements scope, there’s no way for you to access all the variables in a program at all locations in that program. In this case, your ability to access a given name will depend on where you’ve defined that name.

Tên trong các chương trình của bạn sẽ có phạm vi của khối mã mà bạn xác định chúng. Khi bạn có thể truy cập giá trị của một tên nhất định từ nơi nào đó trong mã của bạn, bạn sẽ nói rằng tên nằm trong phạm vi. Nếu bạn có thể truy cập tên, thì bạn sẽ nói rằng tên nằm ngoài phạm vi.in scope. If you can’t access the name, then you’ll say that the name is out of scope.

Tên và phạm vi trong Python

Vì Python là một ngôn ngữ được gõ động, các biến trong Python ra đời khi bạn lần đầu tiên gán cho chúng một giá trị. Mặt khác, các chức năng và các lớp có sẵn sau khi bạn xác định chúng bằng cách sử dụng

>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
5 hoặc
>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
6, tương ứng. Cuối cùng, các mô -đun tồn tại sau khi bạn nhập chúng. Tóm lại, bạn có thể tạo tên Python thông qua một trong các hoạt động sau:

Hoạt độngBản tường trình
Bài tập
>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
7
HOẠT ĐỘNG HOẠT ĐỘNG
>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
8 hoặc
>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
9
Định nghĩa chức năng
>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
0
Định nghĩa đối số trong bối cảnh của các chức năng
>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
1
Định nghĩa lớp
>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
2

Tất cả các hoạt động này tạo ra hoặc, trong trường hợp bài tập, cập nhật tên Python mới vì tất cả chúng gán tên cho một biến, không đổi, chức năng, lớp, thể hiện, mô -đun hoặc đối tượng Python khác.

Python sử dụng vị trí của gán hoặc định nghĩa tên để liên kết nó với một phạm vi cụ thể. Nói cách khác, nơi bạn gán hoặc xác định tên trong mã của bạn xác định phạm vi hoặc khả năng hiển thị của tên đó.

Ví dụ: nếu bạn gán một giá trị cho một tên bên trong một hàm, thì tên đó sẽ có phạm vi Python cục bộ. Ngược lại, nếu bạn gán một giá trị cho một tên bên ngoài tất cả các chức năng, nói rằng, ở cấp cao nhất của một mô -đun thì tên đó sẽ có phạm vi Python toàn cầu.local Python scope. In contrast, if you assign a value to a name outside of all functions—say, at the top level of a module—then that name will have a global Python scope.

Phạm vi Python vs không gian tên

Trong Python, khái niệm về phạm vi có liên quan chặt chẽ đến khái niệm về không gian tên. Như bạn đã học được cho đến nay, một phạm vi Python xác định vị trí trong chương trình của bạn có thể nhìn thấy tên của bạn. Phạm vi Python được triển khai dưới dạng từ điển ánh xạ tên cho các đối tượng. Những từ điển này thường được gọi là không gian tên. Đây là những cơ chế cụ thể mà Python sử dụng để lưu trữ tên. Họ được lưu trữ trong một thuộc tính đặc biệt gọi là

>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
3.namespaces. These are the concrete mechanisms that Python uses to store names. They’re stored in a special attribute called
>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
3.

Tên ở cấp cao nhất của một mô -đun được lưu trữ trong không gian tên mô -đun. Nói cách khác, họ đã được lưu trữ trong thuộc tính mô -đun ____ ____53. Hãy xem mã sau:

>>>

>>> import sys
>>> sys.__dict__.keys[]
dict_keys[['__name__', '__doc__', '__package__',..., 'argv', 'ps1', 'ps2']]

Sau khi bạn nhập

>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
5, bạn có thể sử dụng
>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
6 để kiểm tra các khóa của
>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
7. Điều này trả về một danh sách với tất cả các tên được xác định ở cấp cao nhất của mô -đun. Trong trường hợp này, bạn có thể nói rằng
>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
3 giữ không gian tên của
>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
5 và là một biểu diễn cụ thể của phạm vi mô -đun.

Ví dụ nữa, giả sử rằng bạn cần sử dụng tên

>>> def outer_func[]:
...     var = 100
...     def inner_func[]:
...         print[f"Printing var from inner_func[]: {var}"]
...         print[f"Printing another_var from inner_func[]: {another_var}"]
...
...     inner_func[]
...     another_var = 200  # This is defined after calling inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Traceback [most recent call last]:
  File "", line 1, in 
    outer_func[]
  File "", line 7, in outer_func
    inner_func[]
  File "", line 5, in inner_func
    print[f"Printing another_var from inner_func[]: {another_var}"]
NameError: free variable 'another_var' referenced before assignment in enclosing
 scope
0, được định nghĩa trong
>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
5. Nếu bạn biết cách
>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
3 và không gian tên hoạt động trong Python, thì bạn có thể tham khảo
>>> def outer_func[]:
...     var = 100
...     def inner_func[]:
...         print[f"Printing var from inner_func[]: {var}"]
...         print[f"Printing another_var from inner_func[]: {another_var}"]
...
...     inner_func[]
...     another_var = 200  # This is defined after calling inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Traceback [most recent call last]:
  File "", line 1, in 
    outer_func[]
  File "", line 7, in outer_func
    inner_func[]
  File "", line 5, in inner_func
    print[f"Printing another_var from inner_func[]: {another_var}"]
NameError: free variable 'another_var' referenced before assignment in enclosing
 scope
0 theo ít nhất hai cách khác nhau:

  1. Sử dụng ký hiệu dấu chấm trên tên mô -đun trong mẫu
    >>> def outer_func[]:
    ...     var = 100
    ...     def inner_func[]:
    ...         print[f"Printing var from inner_func[]: {var}"]
    ...         print[f"Printing another_var from inner_func[]: {another_var}"]
    ...
    ...     inner_func[]
    ...     another_var = 200  # This is defined after calling inner_func[]
    ...     print[f"Printing var from outer_func[]: {var}"]
    ...
    >>> outer_func[]
    Printing var from inner_func[]: 100
    Traceback [most recent call last]:
      File "", line 1, in 
        outer_func[]
      File "", line 7, in outer_func
        inner_func[]
      File "", line 5, in inner_func
        print[f"Printing another_var from inner_func[]: {another_var}"]
    NameError: free variable 'another_var' referenced before assignment in enclosing
     scope
    
    4
  2. Sử dụng hoạt động đăng ký trên
    >>> def outer_func[]:
    ...     # This block is the Local scope of outer_func[]
    ...     var = 100  # A nonlocal var
    ...     # It's also the enclosing scope of inner_func[]
    ...     def inner_func[]:
    ...         # This block is the Local scope of inner_func[]
    ...         print[f"Printing var from inner_func[]: {var}"]
    ...
    ...     inner_func[]
    ...     print[f"Printing var from outer_func[]: {var}"]
    ...
    >>> outer_func[]
    Printing var from inner_func[]: 100
    Printing var from outer_func[]: 100
    >>> inner_func[]
    Traceback [most recent call last]:
      File "", line 1, in 
    NameError: name 'inner_func' is not defined
    
    3 ở dạng
    >>> def outer_func[]:
    ...     var = 100
    ...     def inner_func[]:
    ...         print[f"Printing var from inner_func[]: {var}"]
    ...         print[f"Printing another_var from inner_func[]: {another_var}"]
    ...
    ...     inner_func[]
    ...     another_var = 200  # This is defined after calling inner_func[]
    ...     print[f"Printing var from outer_func[]: {var}"]
    ...
    >>> outer_func[]
    Printing var from inner_func[]: 100
    Traceback [most recent call last]:
      File "", line 1, in 
        outer_func[]
      File "", line 7, in outer_func
        inner_func[]
      File "", line 5, in inner_func
        print[f"Printing another_var from inner_func[]: {another_var}"]
    NameError: free variable 'another_var' referenced before assignment in enclosing
     scope
    
    6

Hãy xem mã sau:

>>>

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '

Sau khi bạn nhập

>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
5, bạn có thể sử dụng
>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
6 để kiểm tra các khóa của
>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
7. Điều này trả về một danh sách với tất cả các tên được xác định ở cấp cao nhất của mô -đun. Trong trường hợp này, bạn có thể nói rằng
>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
3 giữ không gian tên của
>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
5 và là một biểu diễn cụ thể của phạm vi mô -đun.

Ví dụ nữa, giả sử rằng bạn cần sử dụng tên

>>> def outer_func[]:
...     var = 100
...     def inner_func[]:
...         print[f"Printing var from inner_func[]: {var}"]
...         print[f"Printing another_var from inner_func[]: {another_var}"]
...
...     inner_func[]
...     another_var = 200  # This is defined after calling inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Traceback [most recent call last]:
  File "", line 1, in 
    outer_func[]
  File "", line 7, in outer_func
    inner_func[]
  File "", line 5, in inner_func
    print[f"Printing another_var from inner_func[]: {another_var}"]
NameError: free variable 'another_var' referenced before assignment in enclosing
 scope
0, được định nghĩa trong
>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
5. Nếu bạn biết cách
>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
3 và không gian tên hoạt động trong Python, thì bạn có thể tham khảo
>>> def outer_func[]:
...     var = 100
...     def inner_func[]:
...         print[f"Printing var from inner_func[]: {var}"]
...         print[f"Printing another_var from inner_func[]: {another_var}"]
...
...     inner_func[]
...     another_var = 200  # This is defined after calling inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Traceback [most recent call last]:
  File "", line 1, in 
    outer_func[]
  File "", line 7, in outer_func
    inner_func[]
  File "", line 5, in inner_func
    print[f"Printing another_var from inner_func[]: {another_var}"]
NameError: free variable 'another_var' referenced before assignment in enclosing
 scope
0 theo ít nhất hai cách khác nhau:

Sử dụng ký hiệu dấu chấm trên tên mô -đun trong mẫu
>>> def outer_func[]:
...     var = 100
...     def inner_func[]:
...         print[f"Printing var from inner_func[]: {var}"]
...         print[f"Printing another_var from inner_func[]: {another_var}"]
...
...     inner_func[]
...     another_var = 200  # This is defined after calling inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Traceback [most recent call last]:
  File "", line 1, in 
    outer_func[]
  File "", line 7, in outer_func
    inner_func[]
  File "", line 5, in inner_func
    print[f"Printing another_var from inner_func[]: {another_var}"]
NameError: free variable 'another_var' referenced before assignment in enclosing
 scope
4

Sử dụng hoạt động đăng ký trên

>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
3 ở dạng
>>> def outer_func[]:
...     var = 100
...     def inner_func[]:
...         print[f"Printing var from inner_func[]: {var}"]
...         print[f"Printing another_var from inner_func[]: {another_var}"]
...
...     inner_func[]
...     another_var = 200  # This is defined after calling inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Traceback [most recent call last]:
  File "", line 1, in 
    outer_func[]
  File "", line 7, in outer_func
    inner_func[]
  File "", line 5, in inner_func
    print[f"Printing another_var from inner_func[]: {another_var}"]
NameError: free variable 'another_var' referenced before assignment in enclosing
 scope
6LEGB rule, which is named after the Python scope for names. The letters in LEGB stand for Local, Enclosing, Global, and Built-in. Here’s a quick overview of what these terms mean:

  • Hãy xem mã sau: is the code block or body of any Python function or

    >>> __name__
    '__main__'
    
    3 expression. This Python scope contains the names that you define inside the function. These names will only be visible from the code of the function. It’s created at function call, not at function definition, so you’ll have as many different local scopes as function calls. This is true even if you call the same function multiple times, or recursively. Each call will result in a new local scope being created.

  • Khi bạn đã nhập

    >>> def outer_func[]:
    ...     # This block is the Local scope of outer_func[]
    ...     var = 100  # A nonlocal var
    ...     # It's also the enclosing scope of inner_func[]
    ...     def inner_func[]:
    ...         # This block is the Local scope of inner_func[]
    ...         print[f"Printing var from inner_func[]: {var}"]
    ...
    ...     inner_func[]
    ...     print[f"Printing var from outer_func[]: {var}"]
    ...
    >>> outer_func[]
    Printing var from inner_func[]: 100
    Printing var from outer_func[]: 100
    >>> inner_func[]
    Traceback [most recent call last]:
      File "", line 1, in 
    NameError: name 'inner_func' is not defined
    
    5, bạn có thể truy cập
    >>> def outer_func[]:
    ...     var = 100
    ...     def inner_func[]:
    ...         print[f"Printing var from inner_func[]: {var}"]
    ...         print[f"Printing another_var from inner_func[]: {another_var}"]
    ...
    ...     inner_func[]
    ...     another_var = 200  # This is defined after calling inner_func[]
    ...     print[f"Printing var from outer_func[]: {var}"]
    ...
    >>> outer_func[]
    Printing var from inner_func[]: 100
    Traceback [most recent call last]:
      File "", line 1, in 
        outer_func[]
      File "", line 7, in outer_func
        inner_func[]
      File "", line 5, in inner_func
        print[f"Printing another_var from inner_func[]: {another_var}"]
    NameError: free variable 'another_var' referenced before assignment in enclosing
     scope
    
    0 bằng cách sử dụng ký hiệu dấu chấm trên
    >>> def outer_func[]:
    ...     # This block is the Local scope of outer_func[]
    ...     var = 100  # A nonlocal var
    ...     # It's also the enclosing scope of inner_func[]
    ...     def inner_func[]:
    ...         # This block is the Local scope of inner_func[]
    ...         print[f"Printing var from inner_func[]: {var}"]
    ...
    ...     inner_func[]
    ...     print[f"Printing var from outer_func[]: {var}"]
    ...
    >>> outer_func[]
    Printing var from inner_func[]: 100
    Printing var from outer_func[]: 100
    >>> inner_func[]
    Traceback [most recent call last]:
      File "", line 1, in 
    NameError: name 'inner_func' is not defined
    
    5. Bạn cũng có thể truy cập
    >>> def outer_func[]:
    ...     var = 100
    ...     def inner_func[]:
    ...         print[f"Printing var from inner_func[]: {var}"]
    ...         print[f"Printing another_var from inner_func[]: {another_var}"]
    ...
    ...     inner_func[]
    ...     another_var = 200  # This is defined after calling inner_func[]
    ...     print[f"Printing var from outer_func[]: {var}"]
    ...
    >>> outer_func[]
    Printing var from inner_func[]: 100
    Traceback [most recent call last]:
      File "", line 1, in 
        outer_func[]
      File "", line 7, in outer_func
        inner_func[]
      File "", line 5, in inner_func
        print[f"Printing another_var from inner_func[]: {another_var}"]
    NameError: free variable 'another_var' referenced before assignment in enclosing
     scope
    
    0 bằng cách sử dụng tra cứu khóa từ điển với khóa
    >>> __name__
    '__main__'
    
    1. Cả hai hành động trả về cùng một kết quả,
    >>> __name__
    '__main__'
    
    2.
    is a special scope that only exists for nested functions. If the local scope is an inner or nested function, then the enclosing scope is the scope of the outer or enclosing function. This scope contains the names that you define in the enclosing function. The names in the enclosing scope are visible from the code of the inner and enclosing functions.

  • Bất cứ khi nào bạn sử dụng tên, chẳng hạn như một biến hoặc tên hàm, Python tìm kiếm thông qua các cấp độ phạm vi khác nhau [hoặc không gian tên] để xác định xem tên có tồn tại hay không. Nếu tên tồn tại, thì bạn sẽ luôn có lần xuất hiện đầu tiên của nó. Nếu không, bạn sẽ gặp lỗi. Bạn sẽ bao gồm cơ chế tìm kiếm này trong phần tiếp theo. is the top-most scope in a Python program, script, or module. This Python scope contains all of the names that you define at the top level of a program or a module. Names in this Python scope are visible from everywhere in your code.

  • Sử dụng quy tắc LegB cho phạm vi Python is a special Python scope that’s created or loaded whenever you run a script or open an interactive session. This scope contains names such as keywords, functions, exceptions, and other attributes that are built into Python. Names in this Python scope are also available from everywhere in your code. It’s automatically loaded by Python when you run a program or script.

Python giải quyết các tên bằng cách sử dụng quy tắc được gọi là LEGB, được đặt tên theo phạm vi Python cho tên. Các chữ cái trong LegB là viết tắt của địa phương, bao quanh, toàn cầu và tích hợp. Ở đây, một cái nhìn tổng quan nhanh về những điều khoản này có nghĩa là gì:

Phạm vi cục bộ [hoặc chức năng] là khối mã hoặc phần thân của bất kỳ chức năng Python hoặc biểu thức

>>> __name__
'__main__'
3 nào. Phạm vi Python này chứa các tên mà bạn xác định bên trong hàm. Những tên này sẽ chỉ hiển thị từ mã của hàm. Nó được tạo ra tại Call Function Call, không phải ở định nghĩa chức năng, do đó, bạn sẽ có nhiều phạm vi cục bộ khác nhau như các cuộc gọi chức năng. Điều này đúng ngay cả khi bạn gọi cùng một hàm nhiều lần hoặc đệ quy. Mỗi cuộc gọi sẽ dẫn đến một phạm vi địa phương mới được tạo ra.

Phạm vi bao quanh [hoặc không thuộc địa] là một phạm vi đặc biệt chỉ tồn tại cho các chức năng lồng nhau. Nếu phạm vi cục bộ là một hàm bên trong hoặc lồng nhau, thì phạm vi bao quanh là phạm vi của hàm bên ngoài hoặc kèm theo. Phạm vi này chứa các tên mà bạn xác định trong hàm kèm theo. Các tên trong phạm vi kèm theo có thể nhìn thấy từ mã của các hàm bên trong và kèm theo.

Phạm vi toàn cầu [hoặc mô-đun] là phạm vi hàng đầu trong chương trình Python, tập lệnh hoặc mô-đun. Phạm vi Python này chứa tất cả các tên mà bạn xác định ở cấp cao nhất của chương trình hoặc mô -đun. Tên trong phạm vi Python này có thể nhìn thấy từ mọi nơi trong mã của bạn.

Phạm vi tích hợp là một phạm vi Python đặc biệt mà đã tạo hoặc tải bất cứ khi nào bạn chạy tập lệnh hoặc mở phiên tương tác. Phạm vi này chứa các tên như từ khóa, chức năng, ngoại lệ và các thuộc tính khác được tích hợp vào Python. Tên trong phạm vi Python này cũng có sẵn từ mọi nơi trong mã của bạn. Nó tự động được tải bởi Python khi bạn chạy một chương trình hoặc tập lệnh.local scope or function scope is a Python scope created at function calls. Every time you call a function, you’re also creating a new local scope. On the other hand, you can think of each

>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
5 statement and
>>> __name__
'__main__'
3 expression as a blueprint for new local scopes. These local scopes will come into existence whenever you call the function at hand.

Theo mặc định, các tham số và tên mà bạn gán bên trong một hàm chỉ tồn tại trong hàm hoặc phạm vi cục bộ được liên kết với lệnh gọi hàm. Khi hàm trở lại, phạm vi cục bộ bị phá hủy và tên bị lãng quên. Ở đây, cách thức hoạt động của nó:

>>>

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400

>>> __name__
'__main__'
6 là một hàm tính toán bình phương của một số đã cho,
>>> __name__
'__main__'
7. Khi bạn gọi hàm, Python tạo ra một phạm vi cục bộ chứa tên
>>> __name__
'__main__'
7 [một đối số] và
>>> __name__
'__main__'
9 [một biến cục bộ]. Sau cuộc gọi đầu tiên đến
>>> __name__
'__main__'
6,
>>> __name__
'__main__'
7 giữ giá trị
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__']
>>> var = 100  # Assign var at the top level of __main__
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__', 'var']
2 và
>>> __name__
'__main__'
9 giữ giá trị là
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__']
>>> var = 100  # Assign var at the top level of __main__
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__', 'var']
4. Lần thứ hai, các tên địa phương sẽ không nhớ các giá trị được lưu trữ trong chúng lần đầu tiên hàm được gọi. Lưu ý rằng
>>> __name__
'__main__'
7 hiện giữ giá trị
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__']
>>> var = 100  # Assign var at the top level of __main__
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__', 'var']
6 và
>>> __name__
'__main__'
9 giữ
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__']
>>> var = 100  # Assign var at the top level of __main__
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__', 'var']
8.

Vì bạn có thể truy cập tên cục bộ từ các câu lệnh nằm ngoài hàm, các chức năng khác nhau có thể xác định các đối tượng có cùng tên. Kiểm tra ví dụ này:

>>>

>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000

>>> __name__
'__main__'
6 là một hàm tính toán bình phương của một số đã cho,
>>> __name__
'__main__'
7. Khi bạn gọi hàm, Python tạo ra một phạm vi cục bộ chứa tên
>>> __name__
'__main__'
7 [một đối số] và
>>> __name__
'__main__'
9 [một biến cục bộ]. Sau cuộc gọi đầu tiên đến
>>> __name__
'__main__'
6,
>>> __name__
'__main__'
7 giữ giá trị
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__']
>>> var = 100  # Assign var at the top level of __main__
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__', 'var']
2 và
>>> __name__
'__main__'
9 giữ giá trị là
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__']
>>> var = 100  # Assign var at the top level of __main__
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__', 'var']
4. Lần thứ hai, các tên địa phương sẽ không nhớ các giá trị được lưu trữ trong chúng lần đầu tiên hàm được gọi. Lưu ý rằng
>>> __name__
'__main__'
7 hiện giữ giá trị
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__']
>>> var = 100  # Assign var at the top level of __main__
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__', 'var']
6 và
>>> __name__
'__main__'
9 giữ
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__']
>>> var = 100  # Assign var at the top level of __main__
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__', 'var']
8.

Vì bạn có thể truy cập tên cục bộ từ các câu lệnh nằm ngoài hàm, các chức năng khác nhau có thể xác định các đối tượng có cùng tên. Kiểm tra ví dụ này:

Lưu ý rằng bạn xác định

>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__']
>>> var = 100  # Assign var at the top level of __main__
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__', 'var']
9 bằng cách sử dụng cùng một biến và tham số mà bạn đã sử dụng trong
>>> __name__
'__main__'
6. Tuy nhiên, vì
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__']
>>> var = 100  # Assign var at the top level of __main__
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__', 'var']
9 có thể thấy các tên bên trong phạm vi địa phương của
>>> __name__
'__main__'
6 và ngược lại, cả hai chức năng đều hoạt động như mong đợi mà không có bất kỳ sự va chạm tên nào.

>>>

>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'

>>> __name__
'__main__'
6 là một hàm tính toán bình phương của một số đã cho,
>>> __name__
'__main__'
7. Khi bạn gọi hàm, Python tạo ra một phạm vi cục bộ chứa tên
>>> __name__
'__main__'
7 [một đối số] và
>>> __name__
'__main__'
9 [một biến cục bộ]. Sau cuộc gọi đầu tiên đến
>>> __name__
'__main__'
6,
>>> __name__
'__main__'
7 giữ giá trị
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__']
>>> var = 100  # Assign var at the top level of __main__
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__', 'var']
2 và
>>> __name__
'__main__'
9 giữ giá trị là
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__']
>>> var = 100  # Assign var at the top level of __main__
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__', 'var']
4. Lần thứ hai, các tên địa phương sẽ không nhớ các giá trị được lưu trữ trong chúng lần đầu tiên hàm được gọi. Lưu ý rằng
>>> __name__
'__main__'
7 hiện giữ giá trị
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__']
>>> var = 100  # Assign var at the top level of __main__
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__', 'var']
6 và
>>> __name__
'__main__'
9 giữ
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__']
>>> var = 100  # Assign var at the top level of __main__
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__', 'var']
8.

Vì bạn có thể truy cập tên cục bộ từ các câu lệnh nằm ngoài hàm, các chức năng khác nhau có thể xác định các đối tượng có cùng tên. Kiểm tra ví dụ này:

Lưu ý rằng bạn xác định

>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__']
>>> var = 100  # Assign var at the top level of __main__
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__', 'var']
9 bằng cách sử dụng cùng một biến và tham số mà bạn đã sử dụng trong
>>> __name__
'__main__'
6. Tuy nhiên, vì
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__']
>>> var = 100  # Assign var at the top level of __main__
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__', 'var']
9 có thể thấy các tên bên trong phạm vi địa phương của
>>> __name__
'__main__'
6 và ngược lại, cả hai chức năng đều hoạt động như mong đợi mà không có bất kỳ sự va chạm tên nào.
is observed when you nest functions inside other functions. The enclosing scope was added in Python 2.2. It takes the form of the local scope of any enclosing function’s local scopes. Names that you define in the enclosing Python scope are commonly known as nonlocal names. Consider the following code:

>>>

>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined

Bạn có thể tránh va chạm tên trong các chương trình của mình bằng cách sử dụng đúng phạm vi Python cục bộ. Điều này cũng làm cho các chức năng khép kín hơn và tạo ra các đơn vị chương trình có thể duy trì. Ngoài ra, vì bạn có thể thay đổi tên địa phương từ các địa điểm từ xa trong mã của bạn, các chương trình của bạn sẽ dễ dàng gỡ lỗi, đọc và sửa đổi hơn.enclosing scope.

Bạn có thể kiểm tra các tên và tham số của một hàm bằng cách sử dụng

>>> var = 100
>>> def func[]:
...     return var  # You can access var from inside func[]
...
>>> func[]
100
>>> var  # Remains unchanged
100
3, đây là một thuộc tính chứa thông tin về mã nội bộ của hàm. Hãy xem mã bên dưới:

>>>

>>> def outer_func[]:
...     var = 100
...     def inner_func[]:
...         print[f"Printing var from inner_func[]: {var}"]
...         print[f"Printing another_var from inner_func[]: {another_var}"]
...
...     inner_func[]
...     another_var = 200  # This is defined after calling inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Traceback [most recent call last]:
  File "", line 1, in 
    outer_func[]
  File "", line 7, in outer_func
    inner_func[]
  File "", line 5, in inner_func
    print[f"Printing another_var from inner_func[]: {another_var}"]
NameError: free variable 'another_var' referenced before assignment in enclosing
 scope

Trong ví dụ mã này, bạn kiểm tra

>>> var = 100
>>> def func[]:
...     return var  # You can access var from inside func[]
...
>>> func[]
100
>>> var  # Remains unchanged
100
3 trên
>>> __name__
'__main__'
6. Đây là một thuộc tính đặc biệt chứa thông tin về mã của hàm Python. Trong trường hợp này, bạn thấy rằng
>>> var = 100
>>> def func[]:
...     return var  # You can access var from inside func[]
...
>>> func[]
100
>>> var  # Remains unchanged
100
6 giữ một tuple chứa các tên mà bạn xác định bên trong
>>> __name__
'__main__'
6.

Các chức năng lồng nhau: Phạm vi kèm theo

Phạm vi bao quanh hoặc không có địa điểm được quan sát thấy khi bạn làm tổ các chức năng bên trong các chức năng khác. Phạm vi kèm theo đã được thêm vào trong Python 2.2. Nó có hình thức của phạm vi cục bộ của bất kỳ hàm nào kèm theo phạm vi cục bộ. Tên mà bạn xác định trong phạm vi Python kèm theo thường được gọi là tên không thuộc địa. Xem xét mã sau:

Khi bạn gọi

>>> var = 100
>>> def func[]:
...     return var  # You can access var from inside func[]
...
>>> func[]
100
>>> var  # Remains unchanged
100
8, bạn cũng sẽ tạo ra một phạm vi địa phương. Phạm vi cục bộ của
>>> var = 100
>>> def func[]:
...     return var  # You can access var from inside func[]
...
>>> func[]
100
>>> var  # Remains unchanged
100
8, đồng thời, phạm vi bao quanh của
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
00. Từ bên trong
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
00, phạm vi này không phải là phạm vi toàn cầu cũng không phải là phạm vi địa phương. Nó có một phạm vi đặc biệt nằm ở giữa hai phạm vi đó và được gọi là phạm vi bao quanh.global scope of your program.

Tất cả các tên mà bạn tạo trong phạm vi kèm theo đều có thể nhìn thấy từ bên trong

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
00, ngoại trừ các tên được tạo sau khi bạn gọi
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
00. Tại đây, một phiên bản mới của
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
04 cho thấy điểm này:

>>>

>>> __name__
'__main__'

Khi bạn gọi

>>> var = 100
>>> def func[]:
...     return var  # You can access var from inside func[]
...
>>> func[]
100
>>> var  # Remains unchanged
100
8, mã chạy xuống điểm mà bạn gọi là
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
00. Tuyên bố cuối cùng của
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
00 cố gắng truy cập
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
08. Tại thời điểm này,
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
08 chưa được xác định, vì vậy Python tăng
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
10 vì nó có thể tìm thấy tên mà bạn đang cố gắng sử dụng.

Cuối cùng nhưng không kém phần quan trọng, bạn có thể sửa đổi các tên trong phạm vi kèm theo từ bên trong hàm lồng nhau trừ khi bạn tuyên bố chúng là

>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
4 trong hàm lồng nhau. Bạn sẽ đề cập đến cách sử dụng
>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
4 sau này trong hướng dẫn này.

>>>

>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__']
>>> var = 100  # Assign var at the top level of __main__
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__', 'var']

Khi bạn gọi

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
17 không có đối số, bạn sẽ nhận được danh sách các tên có sẵn trong phạm vi Python toàn cầu chính của bạn. Lưu ý rằng nếu bạn gán một tên mới [như
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
20 ở đây] ở cấp cao nhất của mô -đun [là
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
13 tại đây], thì tên đó sẽ được thêm vào danh sách được trả về bởi
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
17.

Có một phạm vi Python toàn cầu trên mỗi lần thực hiện chương trình. Phạm vi này vẫn tồn tại cho đến khi chương trình chấm dứt và tất cả các tên của nó bị lãng quên. Mặt khác, lần sau khi bạn chạy chương trình, các tên sẽ nhớ các giá trị của chúng từ lần chạy trước đó.

Bạn có thể truy cập hoặc tham khảo giá trị của bất kỳ tên toàn cầu nào từ bất kỳ nơi nào trong mã của bạn. Điều này bao gồm các chức năng và các lớp học. Ở đây, một ví dụ làm rõ những điểm này:

>>>

>>> var = 100
>>> def func[]:
...     return var  # You can access var from inside func[]
...
>>> func[]
100
>>> var  # Remains unchanged
100

Bên trong

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
23, bạn có thể tự do truy cập hoặc tham chiếu giá trị của
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
20. Điều này không ảnh hưởng đến tên toàn cầu của bạn
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
20, nhưng nó cho bạn thấy rằng
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
20 có thể được truy cập tự do từ trong vòng
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
23. Mặt khác, bạn có thể gán tên toàn cầu bên trong các chức năng trừ khi bạn tuyên bố rõ ràng chúng là tên toàn cầu bằng cách sử dụng câu lệnh
>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
3 mà bạn sẽ thấy sau này.

Bất cứ khi nào bạn gán một giá trị cho một tên trong Python, một trong hai điều có thể xảy ra:

  1. Bạn tạo một tên mớicreate a new name
  2. Bạn cập nhật một tên hiện cóupdate an existing name

Hành vi cụ thể sẽ phụ thuộc vào phạm vi Python trong đó bạn đang gán tên. Nếu bạn cố gắng gán một giá trị cho một tên toàn cầu bên trong một hàm, thì bạn sẽ tạo ra tên đó trong phạm vi địa phương chức năng, bóng tối hoặc ghi đè tên toàn cầu. Điều này có nghĩa là bạn đã thắng được có thể thay đổi hầu hết các biến đã được xác định bên ngoài hàm từ bên trong hàm.

Nếu bạn tuân theo logic này, thì bạn sẽ nhận ra rằng mã sau đây đã giành được công việc như bạn mong đợi:

>>>

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
0

Trong

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
29, bạn cố gắng tăng biến toàn cầu,
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
20. Vì
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
20 được khai báo
>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
3 bên trong
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
29, Python tạo ra một biến cục bộ mới có cùng tên,
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
20, bên trong hàm. Trong quá trình này, Python nhận ra rằng bạn đang cố gắng sử dụng
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
20 cục bộ trước khi được chuyển nhượng đầu tiên [
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
36], do đó, nó tăng
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
37.

Ở đây, một ví dụ khác:

>>>

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
1

Bạn có thể mong đợi có thể in toàn cầu

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
20 và có thể cập nhật
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
20 sau, nhưng một lần nữa bạn nhận được
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
37. Điều xảy ra ở đây là khi bạn chạy phần thân của
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
23, Python quyết định rằng
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
20 là một biến cục bộ vì nó được gán trong phạm vi chức năng. Đây là một lỗi, nhưng là một lựa chọn thiết kế. Python giả định rằng các tên được gán trong phần thân của một hàm là cục bộ cho chức năng đó.

Cho đến thời điểm này, bạn đã bao gồm ba phạm vi Python. Kiểm tra ví dụ sau đây để tóm tắt về nơi họ đặt trong mã của bạn và cách Python tìm kiếm tên thông qua chúng:

>>>

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
2

Khi bạn gọi

>>> var = 100
>>> def func[]:
...     return var  # You can access var from inside func[]
...
>>> func[]
100
>>> var  # Remains unchanged
100
8, bạn sẽ được in trên màn hình của mình. Nhưng làm thế nào để Python tra cứu tên
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
45 trong trường hợp này? Theo quy tắc LegB, bạn sẽ tìm kiếm
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
45 ở những nơi sau:

  1. Bên trong
    >>> sys.ps1
    '>>> '
    >>> sys.__dict__['ps1']
    '>>> '
    
    00: Đây là phạm vi địa phương, nhưng
    >>> sys.ps1
    '>>> '
    >>> sys.__dict__['ps1']
    '>>> '
    
    45 không tồn tại ở đó.
    This is the local scope, but
    >>> sys.ps1
    '>>> '
    >>> sys.__dict__['ps1']
    '>>> '
    
    45 doesn’t exist there.
  2. Bên trong
    >>> var = 100
    >>> def func[]:
    ...     return var  # You can access var from inside func[]
    ...
    >>> func[]
    100
    >>> var  # Remains unchanged
    100
    
    8: Đây là phạm vi bao quanh, nhưng
    >>> sys.ps1
    '>>> '
    >>> sys.__dict__['ps1']
    '>>> '
    
    45 cũng không được xác định ở đó.
    This is the enclosing scope, but
    >>> sys.ps1
    '>>> '
    >>> sys.__dict__['ps1']
    '>>> '
    
    45 isn’t defined there either.
  3. Trong phạm vi mô -đun: Đây là phạm vi toàn cầu và bạn tìm thấy
    >>> sys.ps1
    '>>> '
    >>> sys.__dict__['ps1']
    '>>> '
    
    45 ở đó, vì vậy bạn có thể in
    >>> sys.ps1
    '>>> '
    >>> sys.__dict__['ps1']
    '>>> '
    
    45 lên màn hình.
    This is the global scope, and you find
    >>> sys.ps1
    '>>> '
    >>> sys.__dict__['ps1']
    '>>> '
    
    45 there, so you can print
    >>> sys.ps1
    '>>> '
    >>> sys.__dict__['ps1']
    '>>> '
    
    45 to the screen.

Nếu

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
45 được định nghĩa bên trong phạm vi toàn cầu, thì Python tiếp tục tìm kiếm bằng cách nhìn vào phạm vi tích hợp. Đây là thành phần cuối cùng của quy tắc LegB, như bạn sẽ thấy trong phần tiếp theo.

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
54: Phạm vi tích hợp

Phạm vi tích hợp là một phạm vi Python đặc biệt mà Lừa được thực hiện như một mô-đun thư viện tiêu chuẩn có tên

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
54 trong Python 3.x. Tất cả các đối tượng tích hợp Python, sống trong mô-đun này. Họ tự động tải vào phạm vi tích hợp khi bạn chạy trình thông dịch Python. Python tìm kiếm
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
54 cuối cùng trong tra cứu LegB của nó, vì vậy bạn nhận được tất cả các tên mà nó xác định miễn phí. Điều này có nghĩa là bạn có thể sử dụng chúng mà không cần nhập bất kỳ mô -đun nào.built-in scope is a special Python scope that’s implemented as a standard library module named
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
54 in Python 3.x. All of Python’s built-in objects live in this module. They’re automatically loaded to the built-in scope when you run the Python interpreter. Python searches
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
54 last in its LEGB lookup, so you get all the names it defines for free. This means that you can use them without importing any module.

Lưu ý rằng các tên trong

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
54 luôn được tải vào phạm vi Python toàn cầu của bạn với tên đặc biệt
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
58, như bạn có thể thấy trong mã sau:

>>>

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
3

Trong đầu ra của cuộc gọi đầu tiên đến

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
17, bạn có thể thấy rằng
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
58 luôn có mặt trong phạm vi Python toàn cầu. Nếu bạn kiểm tra
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
58 bằng cách sử dụng
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
17, thì bạn sẽ nhận được toàn bộ danh sách các tên tích hợp Python.

Phạm vi tích hợp mang lại hơn 150 tên cho phạm vi Python toàn cầu hiện tại của bạn. Ví dụ: trong Python 3.8, bạn có thể biết chính xác số lượng tên như sau:

>>>

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
4

Với cuộc gọi đến

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
63, bạn sẽ nhận được số lượng các mục trong
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
64 được trả về bởi
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
17. Điều này trả về 152 tên bao gồm các ngoại lệ, chức năng, loại, thuộc tính đặc biệt và các đối tượng tích hợp Python khác.

Mặc dù bạn có thể truy cập tất cả các đối tượng tích hợp Python này miễn phí [mà không cần nhập bất cứ thứ gì], bạn cũng có thể nhập rõ ràng

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
54 và truy cập các tên bằng ký hiệu DOT. Ở đây, cách thức hoạt động của nó:

>>>

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
5

Bạn có thể nhập

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
54 như bất kỳ mô -đun Python nào khác. Từ thời điểm này, bạn có thể truy cập tất cả các tên trong
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
54 bằng cách sử dụng Tra cứu thuộc tính chấm hoặc tên đủ điều kiện đầy đủ. Điều này có thể khá hữu ích nếu bạn muốn đảm bảo rằng bạn đã giành được một vụ va chạm tên nếu bất kỳ tên toàn cầu nào của bạn ghi đè bất kỳ tên tích hợp nào.

Bạn có thể ghi đè hoặc xác định lại bất kỳ tên tích hợp nào trong phạm vi toàn cầu của bạn. Nếu bạn làm như vậy, thì hãy nhớ rằng điều này sẽ ảnh hưởng đến tất cả các mã của bạn. Hãy xem ví dụ sau:

>>>

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
6

Nếu bạn ghi đè hoặc tham gia lại

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
69, thì
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
70 được tích hợp gốc sẽ bị ảnh hưởng trên tất cả các mã của bạn. Bây giờ, giả sử rằng bạn cần gọi là
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
70 gốc và bạn quên rằng bạn đã gán lại tên. Trong trường hợp này, khi bạn gọi
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
70 một lần nữa, bạn sẽ nhận được
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
73 vì
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
69 hiện giữ một tham chiếu đến một số nguyên, không thể gọi được.

Nếu bạn đang thử nghiệm một số mã và bạn vô tình chỉ định lại tên tích hợp tại dấu nhắc tương tác, thì bạn có thể khởi động lại phiên của mình hoặc chạy

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
75 để xóa xác định lại khỏi phạm vi Python toàn cầu của bạn. Bằng cách này, bạn đã khôi phục tên ban đầu trong phạm vi tích hợp. Nếu bạn xem lại ví dụ của
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
70, thì bạn có thể làm điều gì đó như sau:

>>>

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
7

Khi bạn xóa tên

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
69 tùy chỉnh, bạn sẽ xóa tên khỏi phạm vi toàn cầu của mình. Điều này cho phép bạn truy cập lại
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
70 ban đầu trong phạm vi tích hợp một lần nữa.

Để làm việc xung quanh loại tình huống này, bạn có thể nhập rõ ràng

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
54 và sau đó sử dụng các tên đủ điều kiện đầy đủ, như trong đoạn mã sau:

>>>

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
8

Khi bạn nhập rõ ràng

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
54, bạn có sẵn tên mô -đun trong phạm vi Python toàn cầu của bạn. Từ thời điểm này, bạn có thể sử dụng các tên đủ điều kiện để có được các tên bạn cần một cách rõ ràng từ
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
54, giống như bạn đã làm với
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
82 trong ví dụ trên.

Như một bản tóm tắt nhanh chóng, một số ý nghĩa của phạm vi Python được hiển thị trong bảng sau:

Hoạt độngMã toàn cầuMã địa phươngMã chức năng lồng nhau
Tên truy cập hoặc tham chiếu sống trong phạm vi toàn cầuĐúngĐúngĐúng
Sửa đổi hoặc cập nhật các tên sống trong phạm vi toàn cầuĐúngSửa đổi hoặc cập nhật các tên sống trong phạm vi toàn cầuSửa đổi hoặc cập nhật các tên sống trong phạm vi toàn cầu
Không [trừ khi được tuyên bố
>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
3]
Các tên truy cập hoặc tham chiếu sống trong phạm vi địa phươngKhôngKhông
Có [phạm vi địa phương của riêng nó], không [phạm vi địa phương khác]ĐúngSửa đổi hoặc cập nhật các tên sống trong phạm vi toàn cầuSửa đổi hoặc cập nhật các tên sống trong phạm vi toàn cầu
Không [trừ khi được tuyên bố
>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
3]
Các tên truy cập hoặc tham chiếu sống trong phạm vi địa phươngCác tên truy cập hoặc tham chiếu sống trong phạm vi địa phươngĐúng
Sửa đổi hoặc cập nhật các tên sống trong phạm vi toàn cầuCác tên truy cập hoặc tham chiếu sống trong phạm vi địa phươngCác tên truy cập hoặc tham chiếu sống trong phạm vi địa phươngKhông

Có [phạm vi địa phương của riêng nó], không [phạm vi địa phương khác]

Ghi đè tên trong phạm vi tích hợp

Có [trong quá trình thực thi chức năng]global names from any place in your code, but they can be modified or updated from within the global Python scope.

Các tên truy cập hoặc tham chiếu sống trong phạm vi bao quanh của họlocal names only from inside the local Python scope they were created in or from inside a nested function, but you can’t access them from the global Python scope or from other local scopes. Additionally, you’ve learned that nonlocal names can be accessed from inside nested functions, but they can’t be modified or updated from there.

N/a

  1. >>> square.__code__.co_varnames
    ['base', 'result']
    >>> square.__code__.co_argcount
    1
    >>> square.__code__.co_consts
    [None, 2, 'The square of ', ' is: ']
    >>> square.__code__.co_name
    'square'
    
    3
  2. >>> square.__code__.co_varnames
    ['base', 'result']
    >>> square.__code__.co_argcount
    1
    >>> square.__code__.co_consts
    [None, 2, 'The square of ', ' is: ']
    >>> square.__code__.co_name
    'square'
    
    4

Sửa đổi hoặc cập nhật các tên sống trong phạm vi kèm theo của chúng

Không [trừ khi được tuyên bố
>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
4]

Bạn đã biết rằng khi bạn cố gắng gán một giá trị cho một tên toàn cầu bên trong hàm, bạn tạo một tên cục bộ mới trong phạm vi chức năng. Để sửa đổi hành vi này, bạn có thể sử dụng câu lệnh

>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
3. Với tuyên bố này, bạn có thể xác định một danh sách các tên sẽ được coi là tên toàn cầu.
>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
3 statement
. With this statement, you can define a list of names that are going to be treated as global names.

Tuyên bố bao gồm từ khóa

>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
3 theo sau là một hoặc nhiều tên được phân tách bằng dấu phẩy. Bạn cũng có thể sử dụng nhiều câu lệnh
>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
3 có tên [hoặc danh sách tên]. Tất cả các tên mà bạn liệt kê trong một câu lệnh
>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
3 sẽ được ánh xạ vào phạm vi toàn cầu hoặc mô -đun mà bạn xác định chúng.

Dưới đây, một ví dụ mà bạn cố gắng cập nhật một biến toàn cầu từ trong một hàm:

>>>

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
9

Khi bạn cố gắng gán

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
95 bên trong
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
96, Python giả định rằng
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
95 là địa phương đến
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
96 và tăng
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
37 vì bạn đã cố gắng truy cập một cái tên được xác định.

Nếu bạn muốn mã này hoạt động theo cách bạn mong đợi ở đây, thì bạn có thể sử dụng câu lệnh

>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
3 như sau:

>>>

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
0

Khi bạn cố gắng gán

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
95 bên trong
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
96, Python giả định rằng
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
95 là địa phương đến
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
96 và tăng
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
37 vì bạn đã cố gắng truy cập một cái tên được xác định.

Nếu bạn muốn mã này hoạt động theo cách bạn mong đợi ở đây, thì bạn có thể sử dụng câu lệnh

>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
3 như sau:

Trong phiên bản mới này của

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
96, bạn thêm câu lệnh
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
02 vào phần thân của chức năng ngay trước khi bạn cố gắng thay đổi
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
95. Với sự thay đổi nhỏ bé này, bạn đã ánh xạ tên
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
95 trong phạm vi hàm thành cùng tên trong phạm vi toàn cầu hoặc mô -đun. Từ thời điểm này, bạn có thể tự do sửa đổi
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
95 bên trong
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
96. Tất cả các thay đổi sẽ phản ánh trong biến toàn cầu.

>>>

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
1

Khi bạn cố gắng gán

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
95 bên trong
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
96, Python giả định rằng
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
95 là địa phương đến
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
96 và tăng
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
37 vì bạn đã cố gắng truy cập một cái tên được xác định.

Nếu bạn muốn mã này hoạt động theo cách bạn mong đợi ở đây, thì bạn có thể sử dụng câu lệnh

>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
3 như sau:

Trong phiên bản mới này của

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
96, bạn thêm câu lệnh
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
02 vào phần thân của chức năng ngay trước khi bạn cố gắng thay đổi
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
95. Với sự thay đổi nhỏ bé này, bạn đã ánh xạ tên
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
95 trong phạm vi hàm thành cùng tên trong phạm vi toàn cầu hoặc mô -đun. Từ thời điểm này, bạn có thể tự do sửa đổi
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
95 bên trong
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
96. Tất cả các thay đổi sẽ phản ánh trong biến toàn cầu.

>>>

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
2

Khi bạn cố gắng gán

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
95 bên trong
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
96, Python giả định rằng
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
95 là địa phương đến
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
96 và tăng
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
37 vì bạn đã cố gắng truy cập một cái tên được xác định.

Nếu bạn muốn mã này hoạt động theo cách bạn mong đợi ở đây, thì bạn có thể sử dụng câu lệnh
>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
3 như sau:

Trong phiên bản mới này của

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
96, bạn thêm câu lệnh
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
02 vào phần thân của chức năng ngay trước khi bạn cố gắng thay đổi
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
95. Với sự thay đổi nhỏ bé này, bạn đã ánh xạ tên
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
95 trong phạm vi hàm thành cùng tên trong phạm vi toàn cầu hoặc mô -đun. Từ thời điểm này, bạn có thể tự do sửa đổi
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
95 bên trong
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
96. Tất cả các thay đổi sẽ phản ánh trong biến toàn cầu.
>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
4 statement
. With a
>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
4 statement, you can define a list of names that are going to be treated as nonlocal.

Với tuyên bố

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
02, bạn đã nói với Python để xem xét phạm vi toàn cầu cho tên
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
95. Bằng cách này, biểu thức
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
09 không tạo ra một tên mới trong phạm vi hàm, nhưng cập nhật nó trong phạm vi toàn cầu.

>>>

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
3

Khi bạn cố gắng gán

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
95 bên trong
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
96, Python giả định rằng
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
95 là địa phương đến
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
96 và tăng
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
37 vì bạn đã cố gắng truy cập một cái tên được xác định.

Nếu bạn muốn mã này hoạt động theo cách bạn mong đợi ở đây, thì bạn có thể sử dụng câu lệnh

>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
3 như sau:

>>>

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
4

Khi bạn cố gắng gán

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
95 bên trong
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
96, Python giả định rằng
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
95 là địa phương đến
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
96 và tăng
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
37 vì bạn đã cố gắng truy cập một cái tên được xác định.

Nếu bạn muốn mã này hoạt động theo cách bạn mong đợi ở đây, thì bạn có thể sử dụng câu lệnh

>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
3 như sau:

>>>

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
5

Trong ví dụ này, khi bạn cố gắng xác định tên không thuộc địa bằng cách sử dụng

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
46, Python ngay lập tức tăng
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
40 vì
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
48 không tồn tại trong phạm vi kèm theo của
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
31.

Sử dụng phạm vi kèm theo làm việc đóng cửa

Đóng cửa là một trường hợp sử dụng đặc biệt của phạm vi Python kèm theo. Khi bạn xử lý một hàm lồng nhau làm dữ liệu, các câu lệnh tạo thành hàm đó được đóng gói cùng với môi trường mà chúng thực thi. Đối tượng kết quả được gọi là đóng cửa. Nói cách khác, việc đóng là một chức năng bên trong hoặc lồng nhau mang thông tin về phạm vi bao quanh của nó, mặc dù phạm vi này đã hoàn thành việc thực thi. are a special use case of the enclosing Python scope. When you handle a nested function as data, the statements that make up that function are packaged together with the environment in which they execute. The resulting object is known as a closure. In other words, a closure is an inner or nested function that carries information about its enclosing scope, even though this scope has completed its execution.

Đóng cửa cung cấp một cách để giữ lại thông tin trạng thái giữa các cuộc gọi chức năng. Điều này có thể hữu ích khi bạn muốn viết mã dựa trên khái niệm đánh giá lười biếng hoặc bị trì hoãn. Hãy xem mã sau đây để biết ví dụ về cách đóng cửa hoạt động và cách bạn có thể tận dụng chúng trong Python:

>>>

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
6

Hàm nhà máy đóng cửa của bạn

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
50 có một đối số gọi là
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
51. Bạn có thể sử dụng chức năng này để xây dựng các đóng cửa chạy các hoạt động năng lượng khác nhau. Điều này hoạt động bởi vì mỗi cuộc gọi đến
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
50 đều có bộ thông tin trạng thái riêng. Nói cách khác, nó nhận được giá trị của nó cho
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
51.

Trong ví dụ trên, hàm bên trong

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
54 trước tiên được gán cho
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
55. Trong trường hợp này, chức năng nhớ rằng
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
51 bằng
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
57. Trong ví dụ thứ hai, bạn gọi
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
50 bằng cách sử dụng
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
59 làm đối số. Bằng cách này,
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
60 giữ một đối tượng hàm, nhớ rằng
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
51 là
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
59. Lưu ý rằng bạn có thể tự do sử dụng lại
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
55 và
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
60 vì họ không quên thông tin trạng thái tương ứng của họ.

Để biết ví dụ cuối cùng về cách sử dụng đóng cửa, giả sử rằng bạn cần tính giá trị trung bình của một số dữ liệu mẫu. Bạn thu thập dữ liệu thông qua một luồng các phép đo liên tiếp của tham số mà bạn đang phân tích. Trong trường hợp này, bạn có thể sử dụng một nhà máy đóng cửa để tạo ra một đóng cửa để nhớ các phép đo trước đó trong mẫu. Hãy xem mã sau:

>>>

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
7

Việc đóng cửa mà bạn tạo trong mã trên nhớ thông tin trạng thái của

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
65 giữa các cuộc gọi của
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
66. Bằng cách này, bạn có thể giải quyết vấn đề một cách thanh lịch và pythonic.

Lưu ý rằng nếu luồng dữ liệu của bạn quá lớn, thì chức năng này có thể trở thành một vấn đề về việc sử dụng bộ nhớ. Điều đó bởi vì với mỗi cuộc gọi đến

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
66,
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
65 sẽ giữ một danh sách các giá trị lớn hơn và lớn hơn. Hãy xem mã sau để thực hiện thay thế bằng cách sử dụng
>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
4:

>>>

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
8

Mặc dù giải pháp này là nhiều dòng hơn, bạn không có một danh sách phát triển vô tận nữa. Bây giờ bạn có một giá trị duy nhất cho

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
70 và
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
71. Việc triển khai này hiệu quả hơn rất nhiều về mức tiêu thụ bộ nhớ so với giải pháp trước đó.

Cuối cùng, bạn có thể tìm thấy một số ví dụ về việc sử dụng đóng cửa trong thư viện tiêu chuẩn Python. Ví dụ,

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
72 cung cấp một chức năng có tên
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
73 sử dụng kỹ thuật đóng để tạo các đối tượng chức năng mới có thể được gọi bằng cách sử dụng các đối số được xác định trước. Đây là một ví dụ:

>>>

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
9

Bạn sử dụng

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
74 để xây dựng một đối tượng hàm nhớ thông tin trạng thái, trong đó
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
75. Sau đó, bạn gọi đối tượng này để thực hiện hoạt động năng lượng và nhận kết quả cuối cùng.

Mang tên cho phạm vi với
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
76

Khi bạn viết một chương trình Python, bạn thường tổ chức mã thành một số mô -đun. Để chương trình của bạn hoạt động, bạn sẽ cần phải mang tên trong các mô -đun riêng biệt đó vào mô -đun

>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
13 của bạn. Để làm điều đó, bạn cần phải
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
76 các mô -đun hoặc tên một cách rõ ràng. Đây là cách duy nhất bạn có thể sử dụng những tên đó trong phạm vi Python toàn cầu chính của bạn.

Hãy xem mã sau đây để biết ví dụ về những gì xảy ra khi bạn nhập một số mô -đun và tên tiêu chuẩn:

>>>

>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
0

Đầu tiên bạn nhập

>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
5 và
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
80 từ Thư viện tiêu chuẩn Python. Bằng cách gọi
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
17 không có đối số, bạn có thể thấy rằng các mô -đun này hiện có sẵn cho bạn dưới dạng tên trong phạm vi toàn cầu hiện tại của bạn. Bằng cách này, bạn có thể sử dụng ký hiệu DOT để có quyền truy cập vào các tên được xác định trong
>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
5 và
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
80.

Trong hoạt động

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
76 mới nhất, bạn sử dụng biểu mẫu
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
85. Bằng cách này, bạn có thể sử dụng tên đã nhập trực tiếp trong mã của mình. Nói cách khác, bạn không cần phải sử dụng rõ ràng ký hiệu dấu chấm.

Khám phá phạm vi Python bất thường

Bạn sẽ tìm thấy một số cấu trúc python nơi độ phân giải tên dường như không phù hợp với quy tắc LegB cho phạm vi Python. Các cấu trúc này bao gồm:

  • Sự hiểu biết
  • Khối ngoại lệ
  • Các lớp học và trường hợp

Trong một vài phần tiếp theo, bạn sẽ đề cập đến cách Python Phạm vi hoạt động trên ba cấu trúc này. Với kiến ​​thức này, bạn sẽ có thể tránh các lỗi tinh tế liên quan đến việc sử dụng tên trong các loại cấu trúc python này.

Phạm vi biến hiểu

Cấu trúc đầu tiên mà bạn bao gồm là sự hiểu biết. Sự hiểu biết là một cách nhỏ gọn để xử lý tất cả hoặc một phần của các yếu tố trong một bộ sưu tập hoặc trình tự. Bạn có thể sử dụng toàn bộ để tạo danh sách, từ điển và bộ.comprehension. A comprehension is a compact way to process all or part of the elements in a collection or sequence. You can use comprehensions to create lists, dictionaries, and sets.

Sự hiểu biết bao gồm một cặp dấu ngoặc [

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
86] hoặc niềng răng xoăn [
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
87] chứa một biểu thức, tiếp theo là một hoặc nhiều điều khoản
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
88 và sau đó không hoặc một mệnh đề
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
89 trên mệnh đề
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
88.

Điều khoản

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
88 trong một sự hiểu biết hoạt động tương tự như vòng lặp
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
88 truyền thống. Biến vòng lặp trong một khả năng hiểu là cục bộ với cấu trúc. Kiểm tra mã sau:

>>>

>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
1

Khi bạn chạy danh sách hiểu, biến

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
93 bị lãng quên và bạn có thể truy cập giá trị của nó nữa. Nó không có khả năng bạn cần sử dụng biến này ngoài sự hiểu biết, nhưng bất kể, Python đảm bảo rằng giá trị của nó không còn khả dụng khi sự hiểu biết kết thúc.

Lưu ý rằng điều này chỉ áp dụng cho toàn bộ. Khi nói đến các vòng lặp

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
88 thông thường, biến vòng lặp giữ giá trị cuối cùng được xử lý bởi vòng lặp:

>>>

>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
2

Khi bạn chạy danh sách hiểu, biến

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
93 bị lãng quên và bạn có thể truy cập giá trị của nó nữa. Nó không có khả năng bạn cần sử dụng biến này ngoài sự hiểu biết, nhưng bất kể, Python đảm bảo rằng giá trị của nó không còn khả dụng khi sự hiểu biết kết thúc.

Lưu ý rằng điều này chỉ áp dụng cho toàn bộ. Khi nói đến các vòng lặp
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
88 thông thường, biến vòng lặp giữ giá trị cuối cùng được xử lý bởi vòng lặp:

Bạn có thể tự do truy cập biến vòng lặp

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
93 sau khi vòng lặp kết thúc. Ở đây, biến vòng lặp giữ giá trị cuối cùng được xử lý bởi vòng lặp, đó là
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
96 trong ví dụ này.exception variable. The exception variable is a variable that holds a reference to the exception raised by a
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
97 statement. In Python 3.x, such variables are local to the
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
98 block and are forgotten when the block ends. Check out the following code:

>>>

>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
3

Khi bạn chạy danh sách hiểu, biến

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
93 bị lãng quên và bạn có thể truy cập giá trị của nó nữa. Nó không có khả năng bạn cần sử dụng biến này ngoài sự hiểu biết, nhưng bất kể, Python đảm bảo rằng giá trị của nó không còn khả dụng khi sự hiểu biết kết thúc.

Lưu ý rằng điều này chỉ áp dụng cho toàn bộ. Khi nói đến các vòng lặp

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
88 thông thường, biến vòng lặp giữ giá trị cuối cùng được xử lý bởi vòng lặp:

>>>

>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
4

Khi bạn chạy danh sách hiểu, biến

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
93 bị lãng quên và bạn có thể truy cập giá trị của nó nữa. Nó không có khả năng bạn cần sử dụng biến này ngoài sự hiểu biết, nhưng bất kể, Python đảm bảo rằng giá trị của nó không còn khả dụng khi sự hiểu biết kết thúc.

Lưu ý rằng điều này chỉ áp dụng cho toàn bộ. Khi nói đến các vòng lặp
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
88 thông thường, biến vòng lặp giữ giá trị cuối cùng được xử lý bởi vòng lặp:

Bạn có thể tự do truy cập biến vòng lặp

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
93 sau khi vòng lặp kết thúc. Ở đây, biến vòng lặp giữ giá trị cuối cùng được xử lý bởi vòng lặp, đó là
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
96 trong ví dụ này.L level.

Phạm vi biến ngoại lệclass attributes live. Check out this code:

>>>

>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
5

Khi bạn chạy danh sách hiểu, biến

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
93 bị lãng quên và bạn có thể truy cập giá trị của nó nữa. Nó không có khả năng bạn cần sử dụng biến này ngoài sự hiểu biết, nhưng bất kể, Python đảm bảo rằng giá trị của nó không còn khả dụng khi sự hiểu biết kết thúc.

Lưu ý rằng điều này chỉ áp dụng cho toàn bộ. Khi nói đến các vòng lặp

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
88 thông thường, biến vòng lặp giữ giá trị cuối cùng được xử lý bởi vòng lặp:

>>>

>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
6

Khi bạn chạy danh sách hiểu, biến

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
93 bị lãng quên và bạn có thể truy cập giá trị của nó nữa. Nó không có khả năng bạn cần sử dụng biến này ngoài sự hiểu biết, nhưng bất kể, Python đảm bảo rằng giá trị của nó không còn khả dụng khi sự hiểu biết kết thúc.

Lưu ý rằng điều này chỉ áp dụng cho toàn bộ. Khi nói đến các vòng lặp

>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
88 thông thường, biến vòng lặp giữ giá trị cuối cùng được xử lý bởi vòng lặp:

>>>

>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
7

Trong ví dụ này, bạn cố gắng truy cập thuộc tính

>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
24. Vì thuộc tính này không tồn tại trong
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
18, bạn nhận được một
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
23 nói với bạn rằng
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
18 không có thuộc tính có tên
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
24.

Bạn cũng có thể truy cập bất kỳ thuộc tính nào bằng cách sử dụng một thể hiện của lớp như sau:

>>>

>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
8

Khi bạn có thể hiện, bạn có thể truy cập các thuộc tính lớp bằng cách sử dụng ký hiệu dấu chấm, như bạn đã làm ở đây với

>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
29. Các thuộc tính lớp dành riêng cho đối tượng lớp, nhưng bạn có thể truy cập chúng từ bất kỳ trường hợp nào của lớp. Nó đáng chú ý rằng các thuộc tính lớp là phổ biến cho tất cả các trường hợp của một lớp. Nếu bạn sửa đổi thuộc tính lớp, thì các thay đổi sẽ được hiển thị trong tất cả các trường hợp của lớp.

Bất cứ khi nào bạn gọi một lớp, bạn sẽ tạo một thể hiện mới của lớp đó. Các trường hợp có thuộc tính

>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
3 riêng của họ giữ tên trong phạm vi địa phương hoặc không gian tên cục bộ. Các tên này thường được gọi là thuộc tính thể hiện và là cục bộ và cụ thể cho từng trường hợp. Điều này có nghĩa là nếu bạn sửa đổi một thuộc tính thể hiện, thì các thay đổi sẽ chỉ hiển thị cho trường hợp cụ thể đó.instance attributes and are local and specific to each instance. This means that if you modify an instance attribute, then the changes will be visible only to that specific instance.

Để tạo, cập nhật hoặc truy cập bất kỳ thuộc tính nào từ bên trong lớp, bạn cần sử dụng

>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
31 cùng với ký hiệu chấm. Ở đây,
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
31 là một thuộc tính đặc biệt đại diện cho thể hiện hiện tại. Mặt khác, để cập nhật hoặc truy cập bất kỳ thuộc tính nào từ bên ngoài lớp, bạn cần tạo một thể hiện và sau đó sử dụng ký hiệu dấu chấm. Ở đây, cách thức hoạt động của nó:

>>>

Khi bạn có thể hiện, bạn có thể truy cập các thuộc tính lớp bằng cách sử dụng ký hiệu dấu chấm, như bạn đã làm ở đây với
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
29. Các thuộc tính lớp dành riêng cho đối tượng lớp, nhưng bạn có thể truy cập chúng từ bất kỳ trường hợp nào của lớp. Nó đáng chú ý rằng các thuộc tính lớp là phổ biến cho tất cả các trường hợp của một lớp. Nếu bạn sửa đổi thuộc tính lớp, thì các thay đổi sẽ được hiển thị trong tất cả các trường hợp của lớp.

Bất cứ khi nào bạn gọi một lớp, bạn sẽ tạo một thể hiện mới của lớp đó. Các trường hợp có thuộc tính

>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
3 riêng của họ giữ tên trong phạm vi địa phương hoặc không gian tên cục bộ. Các tên này thường được gọi là thuộc tính thể hiện và là cục bộ và cụ thể cho từng trường hợp. Điều này có nghĩa là nếu bạn sửa đổi một thuộc tính thể hiện, thì các thay đổi sẽ chỉ hiển thị cho trường hợp cụ thể đó.

Để tạo, cập nhật hoặc truy cập bất kỳ thuộc tính nào từ bên trong lớp, bạn cần sử dụng

>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
31 cùng với ký hiệu chấm. Ở đây,
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
31 là một thuộc tính đặc biệt đại diện cho thể hiện hiện tại. Mặt khác, để cập nhật hoặc truy cập bất kỳ thuộc tính nào từ bên ngoài lớp, bạn cần tạo một thể hiện và sau đó sử dụng ký hiệu dấu chấm. Ở đây, cách thức hoạt động của nó:

>>>

>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
0

Khi bạn có thể hiện, bạn có thể truy cập các thuộc tính lớp bằng cách sử dụng ký hiệu dấu chấm, như bạn đã làm ở đây với

>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
29. Các thuộc tính lớp dành riêng cho đối tượng lớp, nhưng bạn có thể truy cập chúng từ bất kỳ trường hợp nào của lớp. Nó đáng chú ý rằng các thuộc tính lớp là phổ biến cho tất cả các trường hợp của một lớp. Nếu bạn sửa đổi thuộc tính lớp, thì các thay đổi sẽ được hiển thị trong tất cả các trường hợp của lớp.

Bất cứ khi nào bạn gọi một lớp, bạn sẽ tạo một thể hiện mới của lớp đó. Các trường hợp có thuộc tính

>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
3 riêng của họ giữ tên trong phạm vi địa phương hoặc không gian tên cục bộ. Các tên này thường được gọi là thuộc tính thể hiện và là cục bộ và cụ thể cho từng trường hợp. Điều này có nghĩa là nếu bạn sửa đổi một thuộc tính thể hiện, thì các thay đổi sẽ chỉ hiển thị cho trường hợp cụ thể đó.

  1. Để tạo, cập nhật hoặc truy cập bất kỳ thuộc tính nào từ bên trong lớp, bạn cần sử dụng
    >>> def cube[base]:
    ...     result = base ** 3
    ...     print[f'The cube of {base} is: {result}']
    ...
    >>> cube[30]
    The cube of 30 is: 27000
    
    31 cùng với ký hiệu chấm. Ở đây,
    >>> def cube[base]:
    ...     result = base ** 3
    ...     print[f'The cube of {base} is: {result}']
    ...
    >>> cube[30]
    The cube of 30 is: 27000
    
    31 là một thuộc tính đặc biệt đại diện cho thể hiện hiện tại. Mặt khác, để cập nhật hoặc truy cập bất kỳ thuộc tính nào từ bên ngoài lớp, bạn cần tạo một thể hiện và sau đó sử dụng ký hiệu dấu chấm. Ở đây, cách thức hoạt động của nó:instance local scope or namespace first.
  2. >>> def cube[base]:
    ...     result = base ** 3
    ...     print[f'The cube of {base} is: {result}']
    ...
    >>> cube[30]
    The cube of 30 is: 27000
    
    9class local scope or namespace.
  3. Lớp
    >>> def cube[base]:
    ...     result = base ** 3
    ...     print[f'The cube of {base} is: {result}']
    ...
    >>> cube[30]
    The cube of 30 is: 27000
    
    18 có một đối số gọi là
    >>> sys.ps1
    '>>> '
    >>> sys.__dict__['ps1']
    '>>> '
    
    20, được tự động tăng gấp đôi bên trong
    >>> def cube[base]:
    ...     result = base ** 3
    ...     print[f'The cube of {base} is: {result}']
    ...
    >>> cube[30]
    The cube of 30 is: 27000
    
    35 bằng cách sử dụng thao tác gán
    >>> def cube[base]:
    ...     result = base ** 3
    ...     print[f'The cube of {base} is: {result}']
    ...
    >>> cube[30]
    The cube of 30 is: 27000
    
    36. Lưu ý rằng khi bạn kiểm tra
    >>> def outer_func[]:
    ...     # This block is the Local scope of outer_func[]
    ...     var = 100  # A nonlocal var
    ...     # It's also the enclosing scope of inner_func[]
    ...     def inner_func[]:
    ...         # This block is the Local scope of inner_func[]
    ...         print[f"Printing var from inner_func[]: {var}"]
    ...
    ...     inner_func[]
    ...     print[f"Printing var from outer_func[]: {var}"]
    ...
    >>> outer_func[]
    Printing var from inner_func[]: 100
    Printing var from outer_func[]: 100
    >>> inner_func[]
    Traceback [most recent call last]:
      File "", line 1, in 
    NameError: name 'inner_func' is not defined
    
    3 trên
    >>> def cube[base]:
    ...     result = base ** 3
    ...     print[f'The cube of {base} is: {result}']
    ...
    >>> cube[30]
    The cube of 30 is: 27000
    
    38, bạn sẽ nhận được một từ điển chứa tất cả các thuộc tính thể hiện. Trong trường hợp này, từ điển chỉ chứa tên
    >>> sys.ps1
    '>>> '
    >>> sys.__dict__['ps1']
    '>>> '
    
    20, có giá trị hiện là
    >>> def square[base]:
    ...     result = base ** 2
    ...     print[f'The square of {base} is: {result}']
    ...
    >>> square[10]
    The square of 10 is: 100
    >>> result  # Isn't accessible from outside square[]
    Traceback [most recent call last]:
      File "", line 1, in 
        result
    NameError: name 'result' is not defined
    >>> base  # Isn't accessible from outside square[]
    Traceback [most recent call last]:
      File "", line 1, in 
        base
    NameError: name 'base' is not defined
    >>> square[20]
    The square of 20 is: 400
    
    34.
    >>> def cube[base]:
    ...     result = base ** 3
    ...     print[f'The cube of {base} is: {result}']
    ...
    >>> cube[30]
    The cube of 30 is: 27000
    
    23
    .

Mặc dù bạn có thể tạo các thuộc tính thể hiện trong bất kỳ phương thức nào trong một lớp, nhưng nó thực hành tốt để tạo và khởi tạo chúng bên trong

>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
35. Hãy xem phiên bản mới này của
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
18:

Tại đây, bạn sửa đổi

>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
18 để thêm một phương thức mới gọi là
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
44. Sau đó, bạn tạo một thể hiện là
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
18 bằng cách chuyển trong
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__']
>>> var = 100  # Assign var at the top level of __main__
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__', 'var']
4 cho trình khởi tạo lớp. Sau đó, bây giờ bạn có thể gọi
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
44 trên
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
38 để nhân đôi giá trị được lưu trữ trong
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
49. Cuối cùng, nếu bạn cố gắng truy cập
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
20 bằng cách sử dụng đối tượng lớp thay vì một thể hiện, thì bạn sẽ nhận được
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
23 vì các thuộc tính thể hiện có thể được truy cập bằng cách sử dụng các đối tượng lớp.

>>>

>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
1

Khi bạn có thể hiện, bạn có thể truy cập các thuộc tính lớp bằng cách sử dụng ký hiệu dấu chấm, như bạn đã làm ở đây với

>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
29. Các thuộc tính lớp dành riêng cho đối tượng lớp, nhưng bạn có thể truy cập chúng từ bất kỳ trường hợp nào của lớp. Nó đáng chú ý rằng các thuộc tính lớp là phổ biến cho tất cả các trường hợp của một lớp. Nếu bạn sửa đổi thuộc tính lớp, thì các thay đổi sẽ được hiển thị trong tất cả các trường hợp của lớp.

Bất cứ khi nào bạn gọi một lớp, bạn sẽ tạo một thể hiện mới của lớp đó. Các trường hợp có thuộc tính

>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
3 riêng của họ giữ tên trong phạm vi địa phương hoặc không gian tên cục bộ. Các tên này thường được gọi là thuộc tính thể hiện và là cục bộ và cụ thể cho từng trường hợp. Điều này có nghĩa là nếu bạn sửa đổi một thuộc tính thể hiện, thì các thay đổi sẽ chỉ hiển thị cho trường hợp cụ thể đó.

>>>

>>> square.__code__.co_varnames
['base', 'result']
>>> square.__code__.co_argcount
1
>>> square.__code__.co_consts
[None, 2, 'The square of ', ' is: ']
>>> square.__code__.co_name
'square'
2

Khi bạn có thể hiện, bạn có thể truy cập các thuộc tính lớp bằng cách sử dụng ký hiệu dấu chấm, như bạn đã làm ở đây với

>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
29. Các thuộc tính lớp dành riêng cho đối tượng lớp, nhưng bạn có thể truy cập chúng từ bất kỳ trường hợp nào của lớp. Nó đáng chú ý rằng các thuộc tính lớp là phổ biến cho tất cả các trường hợp của một lớp. Nếu bạn sửa đổi thuộc tính lớp, thì các thay đổi sẽ được hiển thị trong tất cả các trường hợp của lớp.

  1. Bất cứ khi nào bạn gọi một lớp, bạn sẽ tạo một thể hiện mới của lớp đó. Các trường hợp có thuộc tính
    >>> def outer_func[]:
    ...     # This block is the Local scope of outer_func[]
    ...     var = 100  # A nonlocal var
    ...     # It's also the enclosing scope of inner_func[]
    ...     def inner_func[]:
    ...         # This block is the Local scope of inner_func[]
    ...         print[f"Printing var from inner_func[]: {var}"]
    ...
    ...     inner_func[]
    ...     print[f"Printing var from outer_func[]: {var}"]
    ...
    >>> outer_func[]
    Printing var from inner_func[]: 100
    Printing var from outer_func[]: 100
    >>> inner_func[]
    Traceback [most recent call last]:
      File "", line 1, in 
    NameError: name 'inner_func' is not defined
    
    3 riêng của họ giữ tên trong phạm vi địa phương hoặc không gian tên cục bộ. Các tên này thường được gọi là thuộc tính thể hiện và là cục bộ và cụ thể cho từng trường hợp. Điều này có nghĩa là nếu bạn sửa đổi một thuộc tính thể hiện, thì các thay đổi sẽ chỉ hiển thị cho trường hợp cụ thể đó.
    Use
    >>> def cube[base]:
    ...     result = base ** 3
    ...     print[f'The cube of {base} is: {result}']
    ...
    >>> cube[30]
    The cube of 30 is: 27000
    
    49 to access this attribute.
  2. Để tạo, cập nhật hoặc truy cập bất kỳ thuộc tính nào từ bên trong lớp, bạn cần sử dụng
    >>> def cube[base]:
    ...     result = base ** 3
    ...     print[f'The cube of {base} is: {result}']
    ...
    >>> cube[30]
    The cube of 30 is: 27000
    
    31 cùng với ký hiệu chấm. Ở đây,
    >>> def cube[base]:
    ...     result = base ** 3
    ...     print[f'The cube of {base} is: {result}']
    ...
    >>> cube[30]
    The cube of 30 is: 27000
    
    31 là một thuộc tính đặc biệt đại diện cho thể hiện hiện tại. Mặt khác, để cập nhật hoặc truy cập bất kỳ thuộc tính nào từ bên ngoài lớp, bạn cần tạo một thể hiện và sau đó sử dụng ký hiệu dấu chấm. Ở đây, cách thức hoạt động của nó:
    Use
    >>> def cube[base]:
    ...     result = base ** 3
    ...     print[f'The cube of {base} is: {result}']
    ...
    >>> cube[30]
    The cube of 30 is: 27000
    
    60 to access this attribute.

>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
9

Lớp

>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
18 có một đối số gọi là
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
20, được tự động tăng gấp đôi bên trong
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
35 bằng cách sử dụng thao tác gán
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
36. Lưu ý rằng khi bạn kiểm tra
>>> def outer_func[]:
...     # This block is the Local scope of outer_func[]
...     var = 100  # A nonlocal var
...     # It's also the enclosing scope of inner_func[]
...     def inner_func[]:
...         # This block is the Local scope of inner_func[]
...         print[f"Printing var from inner_func[]: {var}"]
...
...     inner_func[]
...     print[f"Printing var from outer_func[]: {var}"]
...
>>> outer_func[]
Printing var from inner_func[]: 100
Printing var from outer_func[]: 100
>>> inner_func[]
Traceback [most recent call last]:
  File "", line 1, in 
NameError: name 'inner_func' is not defined
3 trên
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
38, bạn sẽ nhận được một từ điển chứa tất cả các thuộc tính thể hiện. Trong trường hợp này, từ điển chỉ chứa tên
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
20, có giá trị hiện là
>>> def square[base]:
...     result = base ** 2
...     print[f'The square of {base} is: {result}']
...
>>> square[10]
The square of 10 is: 100
>>> result  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    result
NameError: name 'result' is not defined
>>> base  # Isn't accessible from outside square[]
Traceback [most recent call last]:
  File "", line 1, in 
    base
NameError: name 'base' is not defined
>>> square[20]
The square of 20 is: 400
34.

Mặc dù bạn có thể tạo các thuộc tính thể hiện trong bất kỳ phương thức nào trong một lớp, nhưng nó thực hành tốt để tạo và khởi tạo chúng bên trong
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
35. Hãy xem phiên bản mới này của
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
18:

Tại đây, bạn sửa đổi

>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
18 để thêm một phương thức mới gọi là
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
44. Sau đó, bạn tạo một thể hiện là
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
18 bằng cách chuyển trong
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__']
>>> var = 100  # Assign var at the top level of __main__
>>> dir[]
['__annotations__', '__builtins__',..., '__package__', '__spec__', 'var']
4 cho trình khởi tạo lớp. Sau đó, bây giờ bạn có thể gọi
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
44 trên
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
38 để nhân đôi giá trị được lưu trữ trong
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
49. Cuối cùng, nếu bạn cố gắng truy cập
>>> sys.ps1
'>>> '
>>> sys.__dict__['ps1']
'>>> '
20 bằng cách sử dụng đối tượng lớp thay vì một thể hiện, thì bạn sẽ nhận được
>>> def cube[base]:
...     result = base ** 3
...     print[f'The cube of {base} is: {result}']
...
>>> cube[30]
The cube of 30 is: 27000
23 vì các thuộc tính thể hiện có thể được truy cập bằng cách sử dụng các đối tượng lớp.scope of a variable or name defines its visibility throughout your code. In Python, scope is implemented as either a Local, Enclosing, Global, or Built-in scope. When you use a variable or name, Python searches these scopes sequentially to resolve it. If the name isn’t found, then you’ll get an error. This is the general mechanism that Python uses for name resolution and is known as the LEGB rule.

Bây giờ bạn có thể:

  • Tận dụng phạm vi Python để tránh hoặc giảm thiểu các lỗi liên quan đến va chạm tên advantage of Python scope to avoid or minimize bugs related to name collision
  • Sử dụng tốt các tên toàn cầu và địa phương trên các chương trình của bạn để cải thiện khả năng duy trì mã good use of global and local names across your programs to improve code maintainability
  • Sử dụng chiến lược kết hợp để truy cập, sửa đổi hoặc cập nhật tên trên tất cả mã Python của bạn a coherent strategy to access, modify, or update names across all your Python code

Ngoài ra, bạn đã đề cập đến một số công cụ và kỹ thuật liên quan đến phạm vi mà Python cung cấp và cách bạn có thể sử dụng chúng để thu thập thông tin về các tên sống trong một phạm vi nhất định hoặc để sửa đổi hành vi tiêu chuẩn của phạm vi Python. Tất nhiên, có nhiều hơn nữa về chủ đề này mà bên ngoài phạm vi của hướng dẫn này, vì vậy hãy ra khỏi đó và tiếp tục giải quyết độ phân giải tên trong Python!

Phạm vi giải quyết phạm vi trong Python là gì?

Độ phân giải phạm vi được yêu cầu khi một biến được sử dụng để xác định giá trị của nó đến từ đâu. Độ phân giải phạm vi trong Python tuân theo quy tắc LegB. L, địa phương - Tên được gán theo bất kỳ cách nào trong một hàm [hoặc lambda] và không được tuyên bố toàn cầu trong hàm đó.required when a variable is used to determine where should its value be come from. Scope resolution in Python follows the LEGB rule. L, Local — Names assigned in any way within a function [or lambda], and not declared global in that function.

Bốn phạm vi trong Python là gì?

Bạn sẽ tìm hiểu về bốn phạm vi khác nhau với sự trợ giúp của các ví dụ: địa phương, bao quanh, toàn cầu và tích hợp.Các phạm vi này cùng nhau tạo thành cơ sở cho quy tắc LEGB được sử dụng bởi trình thông dịch Python khi làm việc với các biến.local, enclosing, global, and built-in. These scopes together form the basis for the LEGB rule used by the Python interpreter when working with variables.

Quy tắc LGB trong Python giải thích là gì?

Độ phân giải tên của Python đôi khi được gọi là quy tắc LGB, sau khi tên phạm vi: Khi bạn sử dụng tên không đủ tiêu chuẩn bên trong hàm, Python tìm kiếm ba phạm vi của địa phương [L], sau đó là toàn cầu [G], và sau đó là tích hợp [B] Dừng và dừng ở nơi đầu tiên được tìm thấy.name resolution is sometimes called the LGB rule, after the scope names: When you use an unqualified name inside a function, Python searches three scopes—the local [L], then the global [G], and then the built-in [B]—and stops at the first place the name is found.

Có một toán tử phân giải phạm vi trong Python?

Trong Python, quy tắc LEGB được sử dụng để quyết định thứ tự trong đó các không gian tên sẽ được tìm kiếm để giải quyết phạm vi.Các phạm vi được liệt kê dưới đây về phân cấp [cao nhất đến thấp nhất/hẹp đến rộng nhất]: cục bộ [l]: được xác định bên trong hàm/lớp.the LEGB rule is used to decide the order in which the namespaces are to be searched for scope resolution. The scopes are listed below in terms of hierarchy[highest to lowest/narrowest to broadest]: Local[L]: Defined inside function/class.

Bài Viết Liên Quan

Chủ Đề