• python内置函数


    python内置函数

    查看python的内置函数

    >>> dir(__builtins__)
    ['ArithmeticError', 'AssertionError', 'AttributeError', 'BaseException', 'BlockingIOError', 'BrokenPipeError', 'BufferError', 'BytesWarning', 'ChildProcessError', 'ConnectionAbortedError', 'ConnectionError', 'ConnectionRefusedError', 'ConnectionResetError', 'DeprecationWarning', 'EOFError', 'Ellipsis', 'EnvironmentError', 'Exception', 'False', 'FileExistsError', 'FileNotFoundError', 'FloatingPointError', 'FutureWarning', 'GeneratorExit', 'IOError', 'ImportError', 'ImportWarning', 'IndentationError', 'IndexError', 'InterruptedError', 'IsADirectoryError', 'KeyError', 'KeyboardInterrupt', 'LookupError', 'MemoryError', 'ModuleNotFoundError', 'NameError', 'None', 'NotADirectoryError', 'NotImplemented', 'NotImplementedError', 'OSError', 'OverflowError', 'PendingDeprecationWarning', 'PermissionError', 'ProcessLookupError', 'RecursionError', 'ReferenceError', 'ResourceWarning', 'RuntimeError', 'RuntimeWarning', 'StopAsyncIteration', 'StopIteration', 'SyntaxError', 'SyntaxWarning', 'SystemError', 'SystemExit', 'TabError', 'TimeoutError', 'True', 'TypeError', 'UnboundLocalError', 'UnicodeDecodeError', 'UnicodeEncodeError', 'UnicodeError', 'UnicodeTranslateError', 'UnicodeWarning', 'UserWarning', 'ValueError', 'Warning', 'WindowsError', 'ZeroDivisionError', '__build_class__', '__debug__', '__doc__', '__import__', '__loader__', '__name__', '__package__', '__spec__', 'abs', 'all', 'any', 'ascii', 'bin', 'bool', 'bytearray', 'bytes', 'callable', 'chr', 'classmethod', 'compile', 'complex', 'copyright', 'credits', 'delattr', 'dict', 'dir', 'divmod', 'enumerate', 'eval', 'exec', 'exit', 'filter', 'float', 'format', 'frozenset', 'getattr', 'globals', 'hasattr', 'hash', 'help', 'hex', 'id', 'input', 'int', 'isinstance', 'issubclass', 'iter', 'len', 'license', 'list', 'locals', 'map', 'max', 'memoryview', 'min', 'next', 'object', 'oct', 'open', 'ord', 'pow', 'print', 'property', 'quit', 'range', 'repr', 'reversed', 'round', 'set', 'setattr', 'slice', 'sorted', 'staticmethod', 'str', 'sum', 'super', 'tuple', 'type', 'vars', 'zip']
    

    作用域相关 ★★★★★

    locals() 函数会以字典的类型返回当前位置的全部局部变量。若在最外面,与globals()相同。

    globals() 函数以字典的类型返回全部全局变量。

    a = 1
    b = 2
    def f1():
        c = 1
        print('inner locals>>>>', locals())
    f1()
    print('globals>>>>', globals())
    print('outer locals>>>>', locals())
    
    print(globals() == locals())  # 若在最外面,与globals()相同。结果为True
    '''
    inner locals>>>> {'c': 1}
    globals>>>> {'__name__': '__main__', '__doc__': None, '__package__': None, '__loader__': <_frozen_importlib_external.SourceFileLoader object at 0x00000262523AC1D0>, '__spec__': None, '__annotations__': {}, '__builtins__': <module 'builtins' (built-in)>, '__file__': 'E:\oldboy_project\test3.py', '__cached__': None, 'a': 1, 'b': 2, 'f1': <function f1 at 0x00000262522A2E18>}
    outer 
    locals >>>> {'__name__': '__main__', '__doc__': None, '__package__': None, '__loader__': <_frozen_importlib_external.SourceFileLoader object at 0x00000262523AC1D0>, '__spec__': None, '__annotations__': {}, '__builtins__': <module 'builtins' (built-in)>, '__file__': 'E:\oldboy_project\test3.py', '__cached__': None, 'a': 1, 'b': 2, 'f1': <function f1 at 0x00000262522A2E18>}
    True
    '''
    

    其他相关

    字符串类型代码的执行 eval,exec,complie,不建议使用★★★☆☆

    # print(eval('x')) # not defined
    x = 1
    print(eval('x + 3')) # 4
    print(exec('x + 3')) # None
    

    输入输出相关 input,print ★★★★★

      input:函数接受一个标准输入数据,返回为 string 类型。参数默认为None,若给了字符串,会出现提示内容。

      print:打印输出。

    print(*args, sep=' ', end='
    ', file=sys.stdout, flush=False)
    sep 是args每个参数显示的间隔。
    end 是最后以什么结束。
    file 接收文件句柄,可以赋值给一个文本文件。
    flush 立即把内容输出到流文件,不作缓存
    
    with open('print.txt', mode='w', encoding='utf-8') as f:
        print('hello world!I am learning python.', file=f)
    # 命令行中没有显示结果,而新建了一个“print.txt"文件,里面有所写的内容。
    
    print(1, 2, 3, sep='|') # 1|2|3
    

    内存相关 hash id ★★★☆☆

    • hash:获取一个对象(可哈希对象:int,str,Bool,tuple)的哈希值。
      hash一般会得到一个长度为18的数字,
      若是数值长度超过18会得到一个长度18的数字。
      长度小于18会是它原来的数值。
    >>> a = 100
    >>> b = '100'
    >>> c = True
    >>> tu = (1, 2)
    >>> hash(a)    #数字还是它所显示的值。
    100
    >>> hash(b)
    5677959494014640638
    >>> hash(c)
    1
    >>> hash(tu)
    3713081631934410656
    
    • id: 获取该对象的内存地址。

    文件操作相关

    open() ★★★★★

    函数用于打开一个文件,创建一个 file 对象,相关的方法才可以调用它进行读写。

    模块相关__import__  ★★★☆☆

     __import__:函数用于动态加载类和函数 。

    帮助 help:函数用于查看函数或模块用途的详细说明。 ★★☆☆☆

    name = 'alex'
    print(help(str))
    

      

    调用相关

      callable:函数用于检查一个对象是否是可调用的。如果返回True,object仍然可能调用失败;但如果返回False,调用对象ojbect绝对不会成功。 ★★★☆☆

    >>> def f1():
    ...     print('a')
    ...
    >>> callable(f1)
    True
    >>> name = 'python'
    >>> callable(name)
    False
    

    查看内置属性 ★★★☆☆

      dir:函数不带参数时,返回当前范围内的变量、方法和定义的类型列表;带参数时,返回参数的属性、方法列表。
    如果参数包含方法__dir__(),该方法将被调用。如果参数不包含__dir__(),该方法将最大限度地收集参数信息。

    >>> s = 'abc'
    >>> dir(s)
    ['__add__', '__class__', '__contains__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getnewargs__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__len__', '__lt__', '__mod__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__rmod__', '__rmul__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', 'capitalize', 'casefold', 'center', 'count', 'encode', 'endswith', 'expandtabs', 'find', 'format', 'format_map', 'index', 'isalnum', 'isalpha', 'isdecimal', 'isdigit', 'isidentifier', 'islower', 'isnumeric', 'isprintable', 'isspace', 'istitle', 'isupper', 'join', 'ljust', 'lower', 'lstrip', 'maketrans', 'partition', 'replace', 'rfind', 'rindex', 'rjust', 'rpartition', 'rsplit', 'rstrip', 'split', 'splitlines', 'startswith', 'strip', 'swapcase', 'title', 'translate', 'upper', 'zfill']
    

    迭代生成器相关

    range:函数可创建一个整数对象,一般用在 for 循环中。

     python2x: range(3) ---> [0,1,2] 列表
               xrange(3) ---> 一个生成器
     python3x: range(3) ---> range(0,3) 可迭代对象
    

    next:内部实际使用了__next__方法,返回迭代器的下一个项目。

    # 首先获得Iterator对象:
    it = iter([1, 2, 3, 4, 5])
    # 循环:
    while True:
        try:
            # 获得下一个值:
            x = next(it)
            print(x)
        except StopIteration:
            # 遇到StopIteration就退出循环
            break
    

    iter:函数用来生成迭代器(讲一个可迭代对象,生成迭代器)。

    from collections import Iterable
    from collections import Iterator
    l = [1,2,3]
    print(isinstance(l,Iterable))  # True
    print(isinstance(l,Iterator))  # False
    
    l1 = iter(l)
    print(isinstance(l1,Iterable))  # True
    print(isinstance(l1,Iterator))  # True
    
    

    我是位置1

    基础数据类型相关

    数字相关

    数据类型(4)

    bool :用于将给定参数转换为布尔类型,如果没有参数,返回 False。
    >>> bool()
    False
    >>> bool(0)==bool('')==bool([])==bool(tuple())==bool(set())==bool({})
    True
    
    int:函数用于将一个字符串或数字转换为整型。
    >>> int('10', base=2)  #二进制转十进制
    2
    >>> int('10', base=8)  #八进制转十进制
    8
    >>> int('1e', base=16) #十六进制转十进制
    30
    >>> int(3.8)   # 浮点数强制转整形
    3
    >>> int()   # 默认为0
    0
    
    
    float:函数用于将整数和字符串转换成浮点数。
    >>> float()
    0.0
    >>> float('+1.23')
    1.23
    >>> float('   -12345
    ')
    -12345.0
    >>> float('1e-003')
    0.001
    >>> float('+1E6')
    1000000.0
    >>> float('-Infinity')
    -inf
    
    
    complex:

    函数用于创建一个值为 real + imag * j 的复数或者转化一个字符串或数为复数。如果第一个参数为字符串,则不需要指定第二个参数。

    进制转换(3)

    bin:将十进制转换成二进制并返回。
    >>> bin(3)
    '0b11'
    >>> bin(-10)
    '-0b1010'
    
    oct:将十进制转化成八进制字符串并返回。
    >>> oct(8)
    '0o10'
    >>> oct(-56)
    '-0o70'
    
    hex:将十进制转化成十六进制字符串并返回。
    >>> hex(255)
    '0xff'
    >>> hex(-42)
    '-0x2a'
    

    数学运算(7):

    abs:函数返回数字的绝对值。
    >>> abs(-20)
    20
    >>> abs(-28.33)
    28.33
    
    divmod:计算除数与被除数的结果,返回一个包含商和余数的元组(a // b, a % b),可以用到页码的计算。
    >>> divmod(2.4, 1.1)
    (2.0, 0.19999999999999973)
    >>> divmod(33, 15)
    (2, 3)
    >>>
    
    round:保留浮点数的小数位数,默认保留整数。
    >>> round(0.5)
    0
    >>> round(1.5)
    2
    #  if two multiples are equally close, rounding is done toward the even choice # (so, for example, both round(0.5) and round(-0.5) are 0, and round(1.5) is 2). 
    
    pow:求xy次幂。(三个参数为xy的结果对z取余)
    >>> pow(3, -2, 3)
    Traceback (most recent call last):
      File "<stdin>", line 1, in <module>
    ValueError: pow() 2nd argument cannot be negative when 3rd argument specified
    >>> pow(3, 2, 7)
    2
    
    sum:对可迭代对象进行求和计算(可设置初始值)。
    >>> sum([1,2,3,4], 10)
    20
    
    min:返回可迭代对象的最小值(可加key,key为函数名,通过函数的规则,返回最小值)。 key可以跟lambda函数用。
    >>> min([-1, 3, 4, 9, -10])
    -10
    >>> min([-1, 3, 4, 9, -10], key=abs)
    -1
    
    max:返回可迭代对象的最大值(可加key,key为函数名,通过函数的规则,返回最大值)。key可以跟lambda函数用。
    >>> max([-1, 3, 4, 9, -10])
    9
    >>> max([-1, 3, 4, 9, -10], key=abs)
    -10
    

    和数据结构相关

    列表和元祖(2)

    list:将一个可迭代对象转化成列表(如果是字典,默认将key作为列表的元素)。
    >>> list({'a':1, 'b':3})
    ['a', 'b']
    
    tuple:将一个可迭代对象转化成元祖(如果是字典,默认将key作为元祖的元素)。

    相关内置函数(2)

    reversed:将一个序列翻转,并返回此翻转序列的迭代器。
    >>> reversed([3,1,6,4,9])   # Return a reverse iterator. 
    <list_reverseiterator object at 0x000001B2B4258E80> 
    >>> list(reversed([3,1,6,4,9]))
    [9, 4, 6, 1, 3]
    
    slice:构造一个切片对象,用于列表的切片。
    >>> li = ['a','b','c','d','e','f','g']
    >>> li[slice(3)]
    ['a', 'b', 'c']
    >>> li[slice(1, 3)]
    ['b', 'c']
    >>> li[slice(1, None, 2)]
    ['b', 'd', 'f']
    >>> li[slice(1, None, 1)]
    ['b', 'c', 'd', 'e', 'f', 'g']
    

    字符串相关(9)

    数据集合(3)

    相关内置函数(8)

    匿名函数

  • 相关阅读:
    java中 Hex(十六进制)和byte[]相互转换
    byte[]和File相互转换
    Stringboot MultiPartFile 转 File
    mysql8.0+运行报错The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents more than one time zone. 解决办法
    idea激活
    mysql8安装成功过后navicat连接失败
    AJAX的使用
    单文件上传和多文件上传实例
    监听器的使用
    SQL分页技术
  • 原文地址:https://www.cnblogs.com/lanhoo/p/9514330.html
Copyright © 2020-2023  润新知