zoukankan      html  css  js  c++  java
  • Python fullstack系列【2】Python数据类型

    基本数据类型

    学习一门编程语言通常都是先了解其不同的数据类型,以及每种数据类型对象所附带的方法,Python也不例外,本篇就详细介绍下这部分。

    Python基本数据类型总览:

    1.Booleans(布尔型):其值为True或False

    2.数值型,包含以下几种:

    integer(整数型)

    float(浮点型)

    fraction(分数)

    复数

    3.Strings(字符串) :元素不可修改

    4.List(列表):有序可修改

    5.Dictionary(字典):无序可修改的键值对

    6.Tuple(元组):有序且不可修改

    7.Set(集合):无序的,通常用来求交并集。

    在说Python的数据类型前,先说说类和对象,Python.org是这样解释两者关系的:对象是对客观事物的抽象,而类是对对象的抽象。 

    dir(类名)可以查看改类都含有哪些方法,help(类名)是对这些类所含方法的详细描述。Python还可以help(类名.方法名),单独查看该方法的描述,如help(list.sort)
    另外在pycharm中也可以通过Ctrl+类查看Python内部定义描述。

    下面开始介绍Python的各种数据类型及常用方法。

    1、布尔型

    1或0

    真或假

    2、数字

    int(整型)

      在32位机器上,整数的位数为32位,取值范围为-2**31~2**31-1,即-2147483648~2147483647
      在64位系统上,整数的位数为64位,取值范围为-2**63~2**63-1,即-9223372036854775808~9223372036854775807

    Python内存优化 -5~257是经常用的数,内部还用一份内存。(实测IDLE上到256,pycharm内到257,如a1 = 257 ,a2 = 257,a1 is a2,IDLE上显示为True,pycharm内显示为false)

    超出范围自动转换为long int(3.5中貌似没这种长度限制)

    long 类型:无限制

      1 class int(object):
      2     """
      3     int(x=0) -> int or long
      4     int(x, base=10) -> int or long
      5 
      6     Convert a number or string to an integer, or return 0 if no arguments
      7     are given.  If x is floating point, the conversion truncates towards zero.
      8     If x is outside the integer range, the function returns a long instead.
      9 
     10     If x is not a number or if base is given, then x must be a string or
     11     Unicode object representing an integer literal in the given base.  The
     12     literal can be preceded by '+' or '-' and be surrounded by whitespace.
     13     The base defaults to 10.  Valid bases are 0 and 2-36.  Base 0 means to
     14     interpret the base from the string as an integer literal.
     15     >>> int('0b100', base=0)
     16     """
     17     def bit_length(self):
     18         """ 返回表示该数字的时占用的最少位数 """
     19         """
     20         int.bit_length() -> int
     21 
     22         Number of bits necessary to represent self in binary.
     23         >>> bin(37)
     24         '0b100101'
     25         >>> (37).bit_length()
     26         """
     27         return 0
     28 
     29     def conjugate(self, *args, **kwargs): # real signature unknown
     30         """ 返回该复数的共轭复数 """
     31         """ Returns self, the complex conjugate of any int. """
     32         pass
     33 
     34     def __abs__(self):
     35         """ 返回绝对值 """
     36         """ x.__abs__() <==> abs(x) """
     37         pass
     38 
     39     def __add__(self, y):
     40         """ x.__add__(y) <==> x+y """
     41         pass
     42 
     43     def __and__(self, y):
     44         """ x.__and__(y) <==> x&y """
     45         pass
     46 
     47     def __cmp__(self, y):
     48         """ 比较两个数大小 """
     49         """ x.__cmp__(y) <==> cmp(x,y) """
     50         pass
     51 
     52     def __coerce__(self, y):
     53         """ 强制生成一个元组 """
     54         """ x.__coerce__(y) <==> coerce(x, y) """
     55         pass
     56 
     57     def __divmod__(self, y):
     58         """ 相除,得到商和余数组成的元组 """
     59         """ x.__divmod__(y) <==> divmod(x, y) """
     60         pass
     61 
     62     def __div__(self, y):
     63         """ x.__div__(y) <==> x/y """
     64         pass
     65 
     66     def __float__(self):
     67         """ 转换为浮点类型 """
     68         """ x.__float__() <==> float(x) """
     69         pass
     70 
     71     def __floordiv__(self, y):
     72         """ x.__floordiv__(y) <==> x//y """
     73         pass
     74 
     75     def __format__(self, *args, **kwargs): # real signature unknown
     76         pass
     77 
     78     def __getattribute__(self, name):
     79         """ x.__getattribute__('name') <==> x.name """
     80         pass
     81 
     82     def __getnewargs__(self, *args, **kwargs): # real signature unknown
     83         """ 内部调用 __new__方法或创建对象时传入参数使用 """
     84         pass
     85 
     86     def __hash__(self):
     87         """如果对象object为哈希表类型,返回对象object的哈希值。哈希值为整数。在字典查找中,哈希值用于快速比较字典的键。两个数值如果相等,则哈希值也相等。"""
     88         """ x.__hash__() <==> hash(x) """
     89         pass
     90 
     91     def __hex__(self):
     92         """ 返回当前数的 十六进制 表示 """
     93         """ x.__hex__() <==> hex(x) """
     94         pass
     95 
     96     def __index__(self):
     97         """ 用于切片,数字无意义 """
     98         """ x[y:z] <==> x[y.__index__():z.__index__()] """
     99         pass
    100 
    101     def __init__(self, x, base=10): # known special case of int.__init__
    102         """ 构造方法,执行 x = 123 或 x = int(10) 时,自动调用,暂时忽略 """
    103         """
    104         int(x=0) -> int or long
    105         int(x, base=10) -> int or long
    106 
    107         Convert a number or string to an integer, or return 0 if no arguments
    108         are given.  If x is floating point, the conversion truncates towards zero.
    109         If x is outside the integer range, the function returns a long instead.
    110 
    111         If x is not a number or if base is given, then x must be a string or
    112         Unicode object representing an integer literal in the given base.  The
    113         literal can be preceded by '+' or '-' and be surrounded by whitespace.
    114         The base defaults to 10.  Valid bases are 0 and 2-36.  Base 0 means to
    115         interpret the base from the string as an integer literal.
    116         >>> int('0b100', base=0)
    117         # (copied from class doc)
    118         """
    119         pass
    120 
    121     def __int__(self):
    122         """ 转换为整数 """
    123         """ x.__int__() <==> int(x) """
    124         pass
    125 
    126     def __invert__(self):
    127         """ x.__invert__() <==> ~x """
    128         pass
    129 
    130     def __long__(self):
    131         """ 转换为长整数 """
    132         """ x.__long__() <==> long(x) """
    133         pass
    134 
    135     def __lshift__(self, y):
    136         """ x.__lshift__(y) <==> x<<y """
    137         pass
    138 
    139     def __mod__(self, y):
    140         """ x.__mod__(y) <==> x%y """
    141         pass
    142 
    143     def __mul__(self, y):
    144         """ x.__mul__(y) <==> x*y """
    145         pass
    146 
    147     def __neg__(self):
    148         """ x.__neg__() <==> -x """
    149         pass
    150 
    151     @staticmethod # known case of __new__
    152     def __new__(S, *more):
    153         """ T.__new__(S, ...) -> a new object with type S, a subtype of T """
    154         pass
    155 
    156     def __nonzero__(self):
    157         """ x.__nonzero__() <==> x != 0 """
    158         pass
    159 
    160     def __oct__(self):
    161         """ 返回改值的 八进制 表示 """
    162         """ x.__oct__() <==> oct(x) """
    163         pass
    164 
    165     def __or__(self, y):
    166         """ x.__or__(y) <==> x|y """
    167         pass
    168 
    169     def __pos__(self):
    170         """ x.__pos__() <==> +x """
    171         pass
    172 
    173     def __pow__(self, y, z=None):
    174         """ 幂,次方 """
    175         """ x.__pow__(y[, z]) <==> pow(x, y[, z]) """
    176         pass
    177 
    178     def __radd__(self, y):
    179         """ x.__radd__(y) <==> y+x """
    180         pass
    181 
    182     def __rand__(self, y):
    183         """ x.__rand__(y) <==> y&x """
    184         pass
    185 
    186     def __rdivmod__(self, y):
    187         """ x.__rdivmod__(y) <==> divmod(y, x) """
    188         pass
    189 
    190     def __rdiv__(self, y):
    191         """ x.__rdiv__(y) <==> y/x """
    192         pass
    193 
    194     def __repr__(self):
    195         """转化为解释器可读取的形式 """
    196         """ x.__repr__() <==> repr(x) """
    197         pass
    198 
    199     def __str__(self):
    200         """转换为人阅读的形式,如果没有适于人阅读的解释形式的话,则返回解释器课阅读的形式"""
    201         """ x.__str__() <==> str(x) """
    202         pass
    203 
    204     def __rfloordiv__(self, y):
    205         """ x.__rfloordiv__(y) <==> y//x """
    206         pass
    207 
    208     def __rlshift__(self, y):
    209         """ x.__rlshift__(y) <==> y<<x """
    210         pass
    211 
    212     def __rmod__(self, y):
    213         """ x.__rmod__(y) <==> y%x """
    214         pass
    215 
    216     def __rmul__(self, y):
    217         """ x.__rmul__(y) <==> y*x """
    218         pass
    219 
    220     def __ror__(self, y):
    221         """ x.__ror__(y) <==> y|x """
    222         pass
    223 
    224     def __rpow__(self, x, z=None):
    225         """ y.__rpow__(x[, z]) <==> pow(x, y[, z]) """
    226         pass
    227 
    228     def __rrshift__(self, y):
    229         """ x.__rrshift__(y) <==> y>>x """
    230         pass
    231 
    232     def __rshift__(self, y):
    233         """ x.__rshift__(y) <==> x>>y """
    234         pass
    235 
    236     def __rsub__(self, y):
    237         """ x.__rsub__(y) <==> y-x """
    238         pass
    239 
    240     def __rtruediv__(self, y):
    241         """ x.__rtruediv__(y) <==> y/x """
    242         pass
    243 
    244     def __rxor__(self, y):
    245         """ x.__rxor__(y) <==> y^x """
    246         pass
    247 
    248     def __sub__(self, y):
    249         """ x.__sub__(y) <==> x-y """
    250         pass
    251 
    252     def __truediv__(self, y):
    253         """ x.__truediv__(y) <==> x/y """
    254         pass
    255 
    256     def __trunc__(self, *args, **kwargs):
    257         """ 返回数值被截取为整形的值,在整形中无意义 """
    258         pass
    259 
    260     def __xor__(self, y):
    261         """ x.__xor__(y) <==> x^y """
    262         pass
    263 
    264     denominator = property(lambda self: object(), lambda self, v: None, lambda self: None)  # default
    265     """ 分母 = 1 """
    266     """the denominator of a rational number in lowest terms"""
    267 
    268     imag = property(lambda self: object(), lambda self, v: None, lambda self: None)  # default
    269     """ 虚数,无意义 """
    270     """the imaginary part of a complex number"""
    271 
    272     numerator = property(lambda self: object(), lambda self, v: None, lambda self: None)  # default
    273     """ 分子 = 数字大小 """
    274     """the numerator of a rational number in lowest terms"""
    275 
    276     real = property(lambda self: object(), lambda self, v: None, lambda self: None)  # default
    277     """ 实属,无意义 """
    278     """the real part of a complex number"""
    279 
    280 int
     
     
     
     
    int

    3、列表

    创建列表这种数据类型后,其实是通过列表这个类来创建对象,这个对象所有的方法如下。

    dir (list) 列出列表这个对象的所有方法:

    ['__add__', '__class__', '__contains__', '__delattr__', '__delitem__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__gt__', '__hash__', '__iadd__', '__imul__', '__init__', '__iter__', '__le__', '__len__', '__lt__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__reversed__', '__rmul__', '__setattr__', '__setitem__', '__sizeof__', '__str__', '__subclasshook__', 'append', 'clear', 'copy', 'count', 'extend', 'index', 'insert', 'pop', 'remove', 'reverse', 'sort']

    注:带__ x__的方法这里先不用关注,这是Python内置的方法,例如执行append方法,Python内部就会调用__add__方法,后面关于面向对象的博文中会详细介绍。

    基本操作包括:

    • 添加
    • 清空
    • 复制
    • 计数
    • 扩展
    • 索引
    • 插入
    • 弹出
    • 删除
    • 反转
    • 排序

    创建列表:

      1 >>> names=['bolen', 'yy', 'kity', 'max', 'hack']
      2 或names=list(['bolen', 'yy', 'kity', 'max', 'hack'])

    切片

      1 >>> names
      2 ['bolen', 'yy', 'kity', 'jack', 'lily']
      3 >>> names[0] #元素从0开始排序
      4 'bolen'
      5 >>> names[0:2] #包前不包后
      6 ['bolen', 'yy']
      7 >>> names[0:-1] #最后一个元素是-1
      8 ['bolen', 'yy', 'kity', 'jack']
      9 >>> names[:-1] #等同于0:-1,:前不写的话默认是0,:后面不写默认是到-1
     10 ['bolen', 'yy', 'kity', 'jack']
     11 
     12 >>> names[2:-1]
     13 ['kity', 'jack']
     14 >>> names[:-1]
     15 ['bolen', 'yy', 'kity', 'jack']
     16 
     17 >>> names[2:] #如果想取到最后一个元素,就不写-1.
     18 ['kity', 'jack', 'lily']
     19 >>> names[0:]
     20 ['bolen', 'yy', 'kity', 'jack', 'lily']
     21 
     22 >>> names[:]
     23 ['bolen', 'yy', 'kity', 'jack', 'lily']
     24 >>> names[::2] # :2代表每隔一个元素取一个
     25 ['bolen', 'kity', 'lily']
     26 >>>
    切片

    append

      1  names
      2 ['bolen', 'yy', 'kity', 'max', 'hack']
      3 names.append('god')
      4 names
      5 ['bolen', 'yy', 'kity', 'max', 'hack', 'god']
    添加列表元素

    clear

      1 names.clear()

    copy

      1 name_new=names.copy()  #要注意深浅拷贝的区别,并且copy和直接将一个变量赋值给另一个变量,数据在内存中的存储是有区别的。详见下一篇
      2 等同于name_new=names

    count

      1 names.count('bolen')#针对某个具体元素出现的次数

    extend&insert

      1 >>> names.insert(2,'插入') #从kity前面插进去~ insert 方法需要指定插入位置
      2 >>> names
      3 ['bolen', 'yy', '插入', 'kity', 'max', 'hack', 'god']
      4 nums=[6,7,8,9]
      5 >>> names+nums
      6 ['bolen', 'yy', '换个姿势', 'kity', 'max', 'hack', 'god', 6, 7, 8, 9]
      7 >>> names
      8 ['bolen', 'yy', '换个姿势', 'kity', 'max', 'hack', 'god']
      9 >>> names.extend(nums)
     10 >>> names
     11 ['bolen', 'yy', '换个姿势', 'kity', 'max', 'hack', 'god', 6, 7, 8, 9]
    扩展和插入

    index(或者列表元素的下标)

      1 >>> names.index('bolen')
      2 0
      3 >>> names.index('hack')
      4 4

    删除(del\pop\remove)

      1 >>> del names[2] #只能指定元素下标
      2 >>> names
      3 ['bolen', 'yy', 'kity', 'max', 'hack', 'god']
      4 >>> names=['bolen', 'yy', '换个姿势', 'kity', 'max', 'hack', 'god']
      5 >>> names.pop() #默认弹出最后一个元素,pop后可加下标
      6 god
      7 >>> names.remove('max') #只能指定具体的元素,不能指定下标。
      8 >>> names
      9 ['bolen', 'yy', '换个姿势', 'kity', 'hack']
    删除元素的三种方法

    sort&reverse

      1 >>> names.sort()#Python3.0中不能对不同数据类型混合排序了
      2 Traceback (most recent call last):
      3   File "<pyshell#43>", line 1, in <module>
      4     names.sort()
      5 TypeError: unorderable types: int() < str()
      6 
      7 >>> nums
      8 [6, 7, 8, 9, 1, 2, 4, 6, 9]
      9 >>> nums.sort()
     10 >>> nums
     11 [1, 2, 4, 6, 6, 7, 8, 9, 9]
     12 
     13 >>> names
     14 ['bolen', 'bolen', 'god', 'hack', 'kity', 'max', 'yy', '换个姿势']
     15 >>> names.append('allen')
     16 >>> names
     17 ['bolen', 'bolen', 'god', 'hack', 'kity', 'max', 'yy', '换个姿势', 'allen']
     18 >>> names.sort()
     19 >>> names
     20 ['allen', 'bolen', 'bolen', 'god', 'hack', 'kity', 'max', 'yy', '换个姿势']
     21 ---------------------------------------------------------
     22 **reverse
     23 >>> names.reverse()
     24 >>> names
     25 ['换个姿势', 'yy', 'max', 'kity', 'hack', 'god', 'bolen', 'bolen', 'allen']
     26 >>> nums.reverse()
     27 >>> nums
     28 [9, 9, 8, 7, 6, 6, 4, 2, 1]
    排序和反转

    4、元组

    元组其实就是不可变的列表,元组中的元素在创建之后不可被修改。

      1 a_tuple=('bolen','a','jack','nick','name')
      2 >>> a_tuple
      3 ('bolen', 'a', 'jack', 'nick', 'name')
      4 >>> a_tuple[0]
      5 'bolen'
      6 >>> a_tuple[-1]
      7 'name'
      8 >>> a_tuple[:-2]
      9 ('bolen', 'a', 'jack')

    元组只能用于查看和切片,对元组切片会产生新的元组,对列表切片也会产生新的列表。
    元组只有两个方法,count和index。
    那么元组和列表的区别是什么呢?

    元组与列表对比

    劣势:

    元组中的元组是不可变的,所以也就没有了列表中的pop、remove、insert、appand、extend等方法。

    优势

    1、元组比列表访问速度快,如果只是想写入元素,不对元素作变更,请用元组;
    2、元组对元素写保护,相对列表会使代码更安全;
    3、元组可作为字典键使用,列表由于是可变的,不会别用作字典键。

    但要注意的是元组中的元素不可变是相对的,例如元组可以接受列表作为元素(嵌套),且这里的列表还是可变的,列表也可以接受元组作为元素。

      1 #便捷的为多变量赋值
      2 >>> n=(1,2,3)
      3 >>> x,y,z=n
      4 >>> x
      5 1
      6 >>> y
      7 2
      8 >>> z
      9 3
     10 #但实测列表也是可以这么赋值的
     11  >>> (MONDAY, TUESDAY, WEDNESDAY, THURSDAY, FRIDAY, SATURDAY, SUNDAY) = range(7)
     12 >>> MONDAY
     13 0
     14 >>> [MONDAY, TUESDAY, WEDNESDAY, THURSDAY, FRIDAY, SATURDAY, SUNDAY] = range(7)
     15 >>> TUESDAY
    元组实际应用举例

    5、字符串

    字符串类型是不可变的,其常用方法如下:

    • 移除空白
    • 分割
    • 长度
    • 索引
    • 切片
    name.capitalize()  #首字母大写
    name.casefold()   #大写全部变小写
    >>> name='bolen'
    >>> name.capitalize()
    'Bolen'
    >>> name.casefold()
    'bolen'
    name.center() #定义宽度和添加的字符
    >>> name.center(50,'=')
    '======================bolen======================='
    name.count('bo') 统计 bo出现次数
    name.encode()  将字符串编码成bytes格式
    >>> new=name.encode()
    >>> type(new)
    <class 'bytes'>
    
    name.endswith("en")  判断字符串是否以 en结尾
    
    >>> 'Bolen\tZhang'.expandtabs(4)
    'Bolen   Zhang
     将\t转换成多长的空格
    
     name.find('A')  查找A,找到返回其索引, 找不到返回-1
    
    format :
        >>> msg = "my name is {}, and age is {}"
        >>> msg.format("bolen",32)
        'my name is bolen, and age is 32'
        >>> msg = "my name is {1}, and age is {0}"
        >>> msg.format("bolen",32)
        'my name is 32, and age is bolen'
        >>> msg = "my name is {name}, and age is {age}"
        >>> msg.format(age=32,name="bolen")
        'my name is ale, and age is 22'
    format_map
        >>> msg.format_map({'name':'jack','age':22})
        'my name is jack, and age is 22'
        #输入字典
    
    msg.index('a')  返回a所在字符串的索引
    >>> 'adf9'.isalnum()
    True
    >>> '9'.isalnum()
    True
    >>>
    
    '9'.isdigit() 是否整数
    name.isnumeric
    name.isprintable
    name.isspace
    name.istitle
    >>> name.title()
    'Bo Le Na'
    >>> name1=name.title()
    >>> name1
    'Bo Le Na'
    >>> name1.istitle()
    True
    name.isupper
    
     "|".join(['alex','jack','rain'])
    'alex|jack|rain'
    
    
    maketrans
    
        >>> intab = "aeiou"  #This is the string having actual characters. 
        >>> outtab = "12345" #This is the string having corresponding mapping character
        >>> trantab = str.maketrans(intab, outtab)
        #先自己制作转换关系表。
        >>> str = "this is string example"
        >>> str.translate(trantab)
        'th3s 3s str3ng 2x1mpl2'
    
     msg.partition('is')   输出 ('my name ', 'is', ' {name}, and age is {age}')
    
     >>> "alex li, chinese name is lijie".replace("li","LI",1)
         'alex LI, chinese name is lijie'
    
     msg.swapcase 大小写互换
    
    
     >>> msg.zfill(40)
     > """方法返回指定长度的字符串,原字符串右对齐,前面填充0。"""
    '00000my name is {name}, and age is {age}'
    
    
    >>> 'Hello world'.ljust(20,"-")
    'Hello world---------'
    >>> 'Hello world'.rjust(20,"*")
    '*********Hello world'
    
    name_define='tWst@123'
    >>> name_define.isidentifier()
    False
    #检测一段字符串可否被当作标志符,即是否符合变量命名规则
    
      def strip(self, chars=None):
            """ 移除两端空白 """
    >>> name=' bole '
    >>> name
    ' bole '
    >>> name.strip()
    'bole'
    str

    6、字典

    创建字典:

    person = {"name": "bolen", 'age': 18}
    或
    person = dict({"name": "
    bolen
    ", 'age': 18})

    常用操作:

    • 索引
    • 新增
    • 删除
    • 键、值、键值对
    • 循环
    • 长度

    字典是键值对的无序集合,且key不能重复。

    #定义
    >>> userdb
    {'user002': 'kobe', 'user003': 'kity', 'user001': 'bolen', 'user004': 'tom'}
    
    #增加
    
    >>> userdb['user005']='baby'
    >>> userdb
    {'user002': 'kobe', 'user003': 'kity', 'user001': 'bolen', 'user004': 'tom', 'user005': 'baby'}
    
    #修改
    
    >>> userdb['user005']='angela'
    >>> userdb
    {'user002': 'kobe', 'user003': 'kity', 'user001': 'bolen', 'user004': 'tom', 'user005': 'angela'}
    
    #删除
    
    字典的删除有三种方式:pop,del和popitem,其中前两种较常用。最后一种由于是随机删除元素的,一般来说并没什么卵用。
    
    >>> userdb.pop('user003')
    'kity'
    >>> userdb
    {'user002': 'kobe', 'user001': 'bolen', 'user004': 'tom', 'user005': 'angela'}
    >>> del userdb['user004']
    >>> userdb
    {'user002': 'kobe', 'user001': 'bolen', 'user005': 'angela'}
    >>> userdb.popitem()
    ('user002', 'kobe')
    
    #查找
    >>> 'user002' in userdb #标准用法
    True
    >>> userdb.get('user004')
    'tom'
    >>> userdb['user004']
    'tom'
    >>> userdb.get('user005')#注意get不到key就没返回值,而下面的取法,get不到key就会报错。
    >>> userdb['user005']
    Traceback (most recent call last):
      File "<pyshell#165>", line 1, in <module>
        userdb['user005']
    KeyError: 'user005'
    #多级嵌套
    
    av_catalog = {
        "欧美":{
            "www.youporn.com": ["很多免费的,世界最大的","质量一般"],
            "www.pornhub.com": ["很多免费的,也很大","质量比yourporn高点"],
            "letmedothistoyou.com": ["多是自拍,高质量图片很多","资源不多,更新慢"],
            "x-art.com":["质量很高,真的很高","全部收费,屌比请绕过"]
        },
        "日韩":{
            "tokyo-hot":["质量怎样不清楚,个人已经不喜欢日韩范了","听说是收费的"]
        },
        "大陆":{
            "1024":["全部免费,真好,好人一生平安","服务器在国外,慢"]
        }
    }
    
    av_catalog["大陆"]["1024"][1] += ",可以用爬虫爬下来"
    print(av_catalog["大陆"]["1024"])
    #ouput 
    ['全部免费,真好,好人一生平安', '服务器在国外,慢,可以用爬虫爬下来']
    其他
    
    #获取keys
    >>> userdb.keys()
    dict_keys(['user002', 'user003', 'user001', 'user004'])
    #获取values
    >>> userdb.values()
    dict_values(['kobe', 'kity', 'bolen', 'tom'])
    #设置默认值,注意此方法是新加,不可修改。
    >>> userdb
    {'user002': 'kobe', 'user003': 'kity', 'user001': 'bolen', 'user006': '希特勒', 'user004': 'tom'}
    >>> userdb.setdefault('user006','bolenzhang')
    '希特勒'
    
    >>> userdb.setdefault('user006','bolenzhang')
    '希特勒'
    >>> userdb
    {'user002': 'kobe', 'user003': 'kity', 'user001': 'bolen', 'user006': '希特勒', 'user004': 'tom'}
    >>> userdb.setdefault('user001','bolenzhang')
    'bolen'
    >>> userdb
    {'user002': 'kobe', 'user003': 'kity', 'user001': 'bolen', 'user006': '希特勒', 'user004': 'tom'}
    
    #update
    >>> newb={'user110':'michal',9:6,1:1}
    >>> newb
    {9: 6, 'user110': 'michal', 1: 1}
    >>> userdb.update(newb)
    >>> userdb
    {1: 1, 'user001': 'bolen', 'user003': 'kity', 'user006': 'xitele', 'user004': 'tom', 9: 6, 'user002': 'kobe', 'user110': 'michal'}
    #获取items
    >>> userdb.items()
    dict_items([(1, 1), ('user001', 'bolen'), ('user003', 'kity'), ('user006', 'xitele'), ('user004', 'tom'), (9, 6), ('user002', 'kobe'), ('user110', 'michal')])
    #通过一个列表生成默认dict,有个没办法解释的坑,少用吧这个
    >>> dict.fromkeys([1,2,3],'test')
    {1: 'test', 2: 'test', 3: 'test'}
    
    #字典的循环
    
    #方法1
    >>> for key in userdb:
        print(userdb[key])
    
    
    1
    bolen
    kity
    xitele
    tom
    6
    kobe
    michal
    >>> userdb
    {1: 1, 'user001': 'bolen', 'user003': 'kity', 'user006': 'xitele', 'user004': 'tom', 9: 6, 'user002': 'kobe', 'user110': 'michal'}
    #方法2
    >>> for k,v in userdb.items():
        print (k,v)
    
    1 1
    user001 bolen
    user003 kity
    user006 xitele
    user004 tom
    9 6
    user002 kobe
    user110 michal
    dict

    7、集合

    集合是一个无序的,不重复的数据组合,它的主要作用如下:

    1、去重,把一个列表变成集合,就自动去重了
    2、关系测试,测试两组数据之前的交集、差集、并集等关系

    # 去重
    >>> b=[1,1,2,3,4,4]
    >>> s = set(b)
    >>> s
    {1, 2, 3, 4}
    s = set([3,5,9,10])      #创建一个数值集合  
    
    t = set("Hello")         #创建一个唯一字符的集合  
    
    
    a = t | s          # t 和 s的并集  
    
    b = t & s          # t 和 s的交集  
    
    c = t – s          # 求差集(项在t中,但不在s中)  
    
    d = t ^ s          # 对称差集(项在t或s中,但不会同时出现在二者中)  
    
    
    基本操作:
    
    t.add('x')            # 添加一项  
    
    s.update([10,37,42])  # 在s中添加多项  
    
    
    使用remove()可以删除一项:
    
    t.remove('H')
    
    
    len(s)
    set 的长度
    
    x in s
    测试 x 是否是 s 的成员
    
    x not in s
    测试 x 是否不是 s 的成员
    
    s.issubset(t)
    s <= t
    测试是否 s 中的每一个元素都在 t 中
    
    s.issuperset(t)
    s >= t
    测试是否 t 中的每一个元素都在 s 中
    
    s.union(t)
    s | t
    返回一个新的 set 包含 s 和 t 中的每一个元素
    
    s.intersection(t)
    s & t
    返回一个新的 set 包含 s 和 t 中的公共元素
    
    s.difference(t)
    s - t
    返回一个新的 set 包含 s 中有但是 t 中没有的元素
    se.difference_update(be)#找se中存在,be中不存在,并更新se.

    se.discard()
    se.remove()#同上,但是没有会报错
    se={11,22,33}
    be={22,95}
    #对称差集(互为差集的合计)
    se.symmetric_difference(be)
    se.symmetric_difference_update(be)

    #交集
    ret=se.intersection(be)
    ret=se.intersection_update(be)
    #有交集是false,没交集True.
    se.isdisjoint(be)
    #父集、子集
    se.issubset(be)
    se.issuperset(be)
    #并集
    ret=se.union(be)

    se.update(be)#把se更新了
    se.update([444,555,666])

    #pop可以拿到移除元素的返回值(集合是无序的,不一定pop谁)
    ret=se.pop()

    s.symmetric_difference(t)
    s ^ t
    返回一个新的 set 包含 s 和 t 中不重复的元素
    s.copy()
    返回 set “s”的一个浅复制
    set

    其他

    1、range

    >>> for i in range(1,10):
    print(i)

    range(1, 10, 2)

    # 结果:[1, 3, 5, 7, 9]

    range(30, 0, -2)

    # 结果:[30, 28, 26, 24, 22, 20, 18, 16, 14, 12, 10, 8, 6, 4, 2]  

    2、enumrate

    为可迭代的对象添加序号

    li = [11,22,33]
    for k,v in enumerate(li, 1):
    print(k,v)
    
    
  • 相关阅读:
    ip报文
    常见端口
    navicat15 破解版
    谷歌跨域设置
    CSS flex弹性布局来做 页面底部自适应:页面高度不足时,在底部显示;页面高度超出时,随页面滚动(亲测有效)
    phpstorm 2019 激活码
    aes cbc模式
    Vue的安装及使用快速入门
    从SVN服务器端彻底删除错误提交版本
    Nginx配置https和wss
  • 原文地址:https://www.cnblogs.com/bolenzhang/p/6725325.html
Copyright © 2011-2022 走看看