zoukankan      html  css  js  c++  java
  • 数据类型

    数据类型

    • string

    1. 创建:

    tmp=' ' / tmp=str(a)

    1. 切片:

    a ='abcde'
    a[0:3] 表示取下标 0-2 的字符 左闭右开
    a[0:3:1] 表示取下标0-2的字符,步长为1

    1. 常见操作:

    [图片上传中...(-39165d-1560650555924-0)]

    1. 循环遍历

    字符串的遍历将会是把字符串拆分成最小单位

    1. 转义字符串

    1. 备注
    • 中文字符串处理:

    在网络上发送字符串时要求必须转换成(bytes)形式,用字符串的encode()方法,返回值是字节串(bytes)
    encode(encoding = 'utf-8',errors = 'strict')
    encoding 默认编码为utf-8,其他还有gbk,gb2312
    errors编码错误的处理方式,默认为strict(报错),也可以是ignore,replace
    反之,从网络上接收到的字符串(bytes)若为字符串,则要使用字节串(bytes)的decode方法来解码,才能看到原来的字符串
    decode(encoding = 'utf-8',errors='strict')
    编码解码时要一致,否则不能还原或者报错
    bytes = str.encode()
    str = bytes.decode()

    • 当py脚本中有中文数据,不能执行时,需要在文件头声明:
    # coding=gbk

    • 字符串填充

    • list

    1. 创建

    a = list() a = [ ] (列表中的元素可以使不同类型的)

    1. 常用操作


    问题:

    a = [1,2,3,4,5,6]
    print(a)
    for i in a:
        if i > 3:
            a.remove(i)
    print(a)
    
    输出:
    [1, 2, 3, 4, 5, 6]
    [1, 2, 3, 5]
    
    按照正常理解,大于3的数据对象是要在列表中删除的,但是输出内容中还存在了5,5小于3?不可能,
    原因:在数据对象遍历到4的时候,列表执行了remove函数,删除了4,列表中的元素就只剩下了 12356,原来是有6个元素,现在只有5个,但是for是按照数据索引走的,原来4的索引是3,for在遍历过3之后,是要遍历4的,但是在删除了4之后,5成了列表中的索引(3),for就把5给跳了过去,直接遍历到了元素6,然后在删除了4 6。剩下了5
    
    要达到设想中的目的,从索引做文章,或者列表拷贝。
    2019年12月22日23:04:23
    可以使用列表的反转来实现
    a = [1,2,3,4,5,6]
    print(a)
    for i in a[::-1]:
        if i > 3:
            a.remove(i)
    print(a)
    [1,2,3]
    为啥?
    
    1. 列表的嵌套
    import random
    #三个空教室
    offices = [[],[],[]]
    #八个老师
    names = [a,b,c,d,e,f,g,h,]
    i = 0
    for name in names:
       index = random.randint(0,2)
       offices[index].append(name)
    i=1
    for tempNames in offices:
       print('办公室%d的人数为:%d' % (i ,len(tempNames)))
       i+=1
       for name in tempNames:
       	print('%d'name)
    
    1. 备注
    • 列表的乘法

    [1]*5 ->[1,1,1,1,1]

    -列表推导式

    [ <i相关表达式> for i in xx]
    [i*2 for i in range(4)]
    [0, 2, 4, 6]
    用循环变量i去遍历xx,将i相关表达式的值放入到一个列表中
    xx:可遍历的对象,列表,元组,range函数

    • dict

    1. 创建

    a={a:b,b:2} a = {}
    特点:

    1. 常用方法:

    普通创建字典的方法
    users = dict(zhang=10000,wang=10000,li=10000,zhao=10000)
    更优雅的方式
    names=["rr","ee,"ww","qq"]
    user1.dict().formatkeys(names,10000) 
    

    获取字典的值

    a={'a':1,'b':'to','c':'63'}
    a['b']
    >>> output:  to
    """
    上面的这种value值获取方式较为常见,但如果a中没有b,
    或者在字典的使用过程中b 这个key被del了呢?
    这是会报一个KeyError的错误,所以养成好习惯,使用下面的方式
    当key值不存在时,返回none,或者自定义一个默认值。
    """
    a.get('b',[default_no可选...])
    

    更新与删除

    #  更新
    a={'a':1,'b':'to','c':'63'}
    a.update('a':2)
    a.update(a=2) # 这种方式同样适用与更新操作
    # 删除某个键值对
    del a['a']
    pop('a')
    """
    两者都可以达到删除某个键值对的操作,
    但后者相当于去除后删除,具备返回值
    """
    del a 删除字典a
    a.clear()清空字典a
    

    has_key操作

    """
    python2中,判断字典是否存在某个值,可以使用has_key('key'),
    但在python3中取消了该参数,如果我们想判断可以使用以下方式:
    """
    a={'a':1,'b':'to','c':'63'}
    'b' in a.keys()
    a.__contains__('b')
    

    字典的enumerate

    a = {'a': 1, 'b': 'to', 'c': '63'}
    for line, item in enumerate(a.items(), start=1):
        print("[{}] {} --> {}".format(line, *item))
    >>> output:
    """
    [1] a --> 1
    [2] b --> to
    [3] c --> 63
    """
    
    1. 循环遍历

    1. 有序字典
      某些时候我们需要保持dict的有序型,这时候可以使用OrderedDict,这是一个dict的子类
    >>> from collections import OrderedDict
    # 无序的dict
    >>> d = {'banana': 3, 'apple': 4, 'pear': 1, 'orange': 2}
    
    # 将d按照key来排序
    >>> OrderedDict(sorted(d.items(), key=lambda t: t[0]))
    OrderedDict([('apple', 4), ('banana', 3), ('orange', 2), ('pear', 1)])
    # 将d按照value来排序
    >>> OrderedDict(sorted(d.items(), key=lambda t: t[1]))
    OrderedDict([('pear', 1), ('orange', 2), ('banana', 3), ('apple', 4)])
    # 将d按照key的长度来排序
    >>> OrderedDict(sorted(d.items(), key=lambda t: len(t[0])))
    OrderedDict([('pear', 1), ('apple', 4), ('orange', 2), ('banana', 3)])
    
    """
    使用popitem(last=True)方法可以让我们按照LIFO(先进后出)的顺序删除dict中的key-value,
    即删除最后一个插入的键值对,如果last=False就按照FIFO(先进先出)删除dict中key-value。
    """
    >>> d = {'banana': 3, 'apple': 4, 'pear': 1, 'orange': 2}
    # 将d按照key来排序
    >>> d = OrderedDict(sorted(d.items(), key=lambda t: t[0]))
    >>> d
    OrderedDict([('apple', 4), ('banana', 3), ('orange', 2), ('pear', 1)])
    # 使用popitem()方法来移除最后一个key-value对
    >>> d.popitem()
    ('pear', 1)
    # 使用popitem(last=False)来移除第一个key-value对
    >>> d.popitem(last=False)
    ('apple', 4)
    
    """
    使用move_to_end(key, last=True)来改变有序的OrderedDict对象的key-value顺序,
    通过这个方法我们可以将排序好的OrderedDict对象中的任意一个key-value,
    插入到字典的开头或者结尾。
    """
    >>> d = OrderedDict.fromkeys('abcde')
    >>> d
    OrderedDict([('a', None), ('b', None), ('c', None), ('d', None), ('e', None)])
    # 将key为b的key-value对移动到dict的最后
    >>> d.move_to_end('b')
    >>> d
    OrderedDict([('a', None), ('c', None), ('d', None), ('e', None), ('b', None)])
    >>> ''.join(d.keys())
    'acdeb'
    # 将key为b的key-value对移动到dict的最前面
    >>> d.move_to_end('b', last=False)
    >>> ''.join(d.keys())
    'bacde'
    
    • tuple

    • set

    • None

    • slice

    例子:

    使代码更易读,

    内置的slice函数,创建了一个切片对象,可以在任何允许切片的地方使用

    items = [0, 1, 2, 3, 4, 5, 6]
    
    a = slice(2,5)
    #slice 对象有几个属性
    print(a.start) # 2
    print(a.step)  # 不指定的话默认是None
    print(a.stop) # 5
    
    b = slice(2,5,2)
    print(b.start) # 2
    print(b.step)  # 2
    print(b.stop) # 5
    # print(items[a])  # 跟items[2:5]作用是一样的
    # [2, 3, 4]
    # print(items[2:5])
    # [2, 3, 4]
    
    # 同时还可以替换列表中的内容
    # items[a] = [0,0,0]  # 直接内存中的值替换
    # print(items)
    # [0, 1, 0, 0, 0, 5, 6]
    
    # 删除
    # del items[a]
    # print(items)
    #[0, 1, 2, 3, 4, 5, 6]  >>  [0, 1, 5, 6]
    
    items = [0, 1, 2, 3, 4, 5, 6]
    
    # a = slice(2,5)
    #slice 对象有几个属性
    # print(a.start) # 2
    # print(a.step)  # 不指定的话默认是None
    # print(a.stop) # 5
    
    # b = slice(2,5,2)
    # print(b.start) # 2
    # print(b.step)  # 2
    # print(b.stop) # 5
    # print(items[a])  # 跟items[2:5]作用是一样的
    # [2, 3, 4]
    # print(items[2:5])
    # [2, 3, 4]
    
    # 同时还可以替换列表中的内容
    # items[a] = [0,0,0]  # 直接内存中的值替换
    # print(items)
    # [0, 1, 0, 0, 0, 5, 6]
    
    # 删除
    # del items[a]
    # print(items)
    #[0, 1, 2, 3, 4, 5, 6]  >>  [0, 1, 5, 6]
    
    
    a = slice(15,20,2)
    s = 'HelloWorld'
    b = a.indices(len(s))
    # 会返回一个三元组(start, stop, step) ,如果a的范围超过s提供的长度,那么所有值都会被自动缩小以满足   边界限制,避免出现 IndexError 异常
    print(b)
    # (10, 10, 2)
    # 对返回的三元组进行拆包,三个参数整好事range的三个参数 start, stop, step
    for i in range(*a.indices(len(s))):
        print(s[i])
    
    
  • 相关阅读:
    操作系统的发展史
    多线程的些许理解(平台x86,具体考虑linux,windows)
    C++ 11 智能指针
    C++虚函数和纯虚函数
    Qt之excel 操作使用说明
    查找之二叉排序树
    图的一些总结
    树的一些总结
    直接插入排序
    冒泡和选择排序
  • 原文地址:https://www.cnblogs.com/cizao/p/11481753.html
Copyright © 2011-2022 走看看