> 文章列表 > 最近才知道的15件关于Python的事情

最近才知道的15件关于Python的事情

最近才知道的15件关于Python的事情

文章目录

    • 1)映射代理(不可变字典
    • 2) __dict__ 对于类和对象是不同的
    • 3) any() 和 all()
    • 4) divmod()
    • 5) 使用格式化字符串轻松检查变量
    • 6) 我们可以将浮点数转换为比率
    • 7) 用globals()和locals()显示现有的全局/本地变量
    • 8) __import__() 函数
    • 9) Python中的无限值
    • 10) 我们可以使用 'pprint' 来漂亮地打印东西
    • 11) 我们可以在Python中打印彩色输出
    • 12) 创建字典的更快方法
    • 13) 我们可以在Python中取消打印的内容
    • 14) 对象中的私有变量并不是真正的私有
    • 15) 我们可以使用'type()'创建类

1)映射代理(不可变字典)


映射代理是创建后无法更改的字典。如果我们不希望用户能够更改我们的值,就可以使用它。

from types import MappingProxyTypemp = MappingProxyType({'apple':4, 'orange':5})
print(mp)# {'apple': 4, 'orange': 5}

如果我们尝试更改映射代理中的内容,就会出现错误。

from types import MappingProxyTypemp = MappingProxyType({'apple':4, 'orange':5})
print(mp)'''
Traceback (most recent call last):File "some/path/a.py", line 4, in <module>mp['apple'] = 10~~^^^^^^^^^
TypeError: 'mappingproxy' object does not support item assignment
'''

2) dict 对于类和对象是不同的


class Dog:def __init__(self, name, age):self.name = nameself.age = agerocky = Dog('rocky', 5)print(type(rocky.__dict__)) # <class 'dict'>
print(rocky.__dict__) # {'name': 'rocky', 'age': 5}print(type(Dog.__dict__)) # <class 'mappingproxy'>
print(Dog.__dict__)
# {'__module__': '__main__', 
# '__init__': <function Dog.__init__ at 0x108f587c0>, 
# '__dict__': <attribute '__dict__' of 'Dog' objects>, 
# '__weakref__': <attribute '__weakref__' of 'Dog' objects>, 
# '__doc__': None}

对象的 dict 属性是普通字典,而类的 dict 属性是映射代理,它们本质上是不可变字典(无法更改)。

3) any() 和 all()


any([True, False, False]) # Trueany([False, False, False]) # Falseall([True, False, False]) # Falseall([True, True, True]) # True

any() 和 all() 函数都接受可迭代对象(例如列表)。

any() 如果至少有一个元素为 True,则返回 True。

all() 只有当所有元素都为 True 时才返回 True。

4) divmod()


内置的divmod()函数可以同时执行//和%运算符。

quotient, remainder = divmod(27, 10)print(quotient)  # 2
print(remainder) # 7

这里,27 // 10 的值为2,而 27 % 10 的值为7。因此,返回元组2,7。

5) 使用格式化字符串轻松检查变量


name = 'rocky'
age = 5string = f'{name=} {age=}'
print(string)# name='rocky' age=5

在格式化字符串中,我们可以在变量后面添加 = 以使用 var_name=var_value 的语法打印它。

6) 我们可以将浮点数转换为比率


print(float.as_integer_ratio(0.5))    # (1, 2)print(float.as_integer_ratio(0.25))   # (1, 4)print(float.as_integer_ratio(1.5))    # (3, 2)

内置的 float.as_integer_ratio() 函数允许我们将浮点数转换为表示分数的元组。但有时它会表现得很奇怪。

print(float.as_integer_ratio(0.1))    # (3602879701896397, 36028797018963968)print(float.as_integer_ratio(0.2))    # (3602879701896397, 18014398509481984)

7) 用globals()和locals()显示现有的全局/本地变量

x = 1
print(globals())# {'__name__': '__main__', '__doc__': None, ..., 'x': 1}

内置的 globals() 函数返回一个包含所有全局变量及其值的字典。

def test():x = 1y = 2print(locals())test()# {'x': 1, 'y': 2}

内置函数 locals() 返回一个包含所有局部变量及其值的字典。

8) import() 函数


import numpy as np
import pandas as pd

^ 导入模块的常规方式。

np = __import__('numpy')
pd = __import__('pandas')

^ 这与上面的代码块执行相同的操作。

9) Python中的无限值

a = float('inf')
b = float('-inf')

^ 我们可以定义正无穷和负无穷。 正无穷大于所有其他数字,而负无穷小于所有其他数字。

10) 我们可以使用 ‘pprint’ 来漂亮地打印东西

from pprint import pprintd = {"A":{"apple":1, "orange":2, "pear":3}, "B":{"apple":4, "orange":5, "pear":6}, "C":{"apple":7, "orange":8, "pear":9}}pprint(d)

最近才知道的15件关于Python的事情

11) 我们可以在Python中打印彩色输出

我们需要先安装colorama。

from colorama import Foreprint(Fore.RED + "hello world")
print(Fore.BLUE + "hello world")
print(Fore.GREEN + "hello world")

最近才知道的15件关于Python的事情

12) 创建字典的更快方法

d1 = {'apple':'pie', 'orange':'juice', 'pear':'cake'}

^ 正常的方式

d2 = dict(apple='pie', orange='juice', pear='cake')

^更快的方法。这与上面的代码块完全相同,但我们输入较少的引号。

13) 我们可以在Python中取消打印的内容

CURSOR_UP = '\\033[1A'
CLEAR = '\\x1b[2K'print('apple')
print('orange')
print('pear')
print((CURSOR_UP + CLEAR)*2, end='') # this unprints 2 lines
print('pineapple')

最近才知道的15件关于Python的事情

14) 对象中的私有变量并不是真正的私有

class Dog:def __init__(self, name):self.__name = name@propertydef name(self):return self.__name

这里,self.__name变量应该是私有的。我们不应该能够从类外部访问它。但实际上我们可以。

rocky = Dog('rocky')
print(rocky.__dict__)    # {'_Dog__name': 'rocky'}

我们可以使用 dict 属性来访问或编辑这些属性。

15) 我们可以使用’type()'创建类

classname = type(name, bases, dict)

name 是一个字符串,代表类的名称
bases 是包含类父类的元组
dict 是包含属性和方法的字典

class Dog:def __init__(self, name, age):self.name = nameself.age = agedef bark(self):print(f'Dog({self.name}, {self.age})')

^ 以正常方式创建一个 Dog 类

def __init__(self, name, age):self.name = nameself.age = agedef bark(self):print(f'Dog({self.name}, {self.age})')Dog = type('Dog', (), {'__init__':__init__, 'bark':bark})

^ 使用 type() 创建与上面完全相同的 Dog 类