自动化测试python趣味100例

python3字典列表混合嵌套

2019-05-11  本文已影响0人  曼木子
实现类似 { key1:   [{}, {}],  key2: [{}, {}]  }的嵌套
import hashlib
'''md5加密'''
def Md5encode(param):
    MD5str = hashlib.md5()
    MD5str.update(str(param).encode(encoding='utf-8'))
    MD5res = MD5str.hexdigest()
    return MD5res
obj = {}
for i in range(100,200):
    i_Md5 = Md5encode(i)
    pre = i_Md5[0:2]
    temp = {"id": str(i), "i_Md5": i_Md5}
    if obj == {}:
       obj = {pre:[temp]}
    else:
        if pre in obj.keys():
            obj[pre].append(temp)
        else:
            obj.update({pre: [temp]})
print(obj)

菜鸟教程:https://www.runoob.com/python3/python3-list.html

1、 列表

列表索引从0开始
list1 = ['a', 'b', 'a',1, 2];
list2 = [1, 2, 3, 4, 5 ];
list3 = ["a", "b", "c", "d"];
列表运算
以列表list1为例
操作符 表示
del list1[2] 删除列表中某一个元素
list1 + list2 列表合并
list1 * 2 列表元素重复2次组成新的列表
list1[-1] 从右边取列表的第一个元素
[list1,list2] 列表嵌套,相当于一个二维数组
函数 表示
len(list1) 列表长度
max(list1) 取列表的最大元素
min(list1) 取列表的最小元素
list(元组) 将元组转化为list列表
list方法 表示
list1.append(list2) 在列表末尾添加新的对象
list1.count('a') 统计某个元素在列表中出现的次数
list1.clear() 清空列表
list1.copy() 列表复制
list1.reverse() 用于反向列表中元素,没有返回值,但是会对列表的元素进行反向排序。
list1.sort( key=None, reverse=False) reverse = True 降序, reverse = False 升序(默认)key ,主要是用来进行比较的元素,只有一个参数
list1.remove('a') 用于移除列表中某个值的第一个匹配项
list1.insert(index, obj) 用于将指定对象插入列表的指定位置,index位置索引。
list1.pop(index) 用于移除列表中的一个元素(默认最后一个元素),并且返回该元素的值。index为位置索引值
list1.extend(seq) 在列表末尾一次性追加另一个序列中的多个值(用新列表扩展原来的列表),seq可以为列表、元组、集合、字典,若为字典,则仅会将键(key)作为元素依次添加至原列表的末尾
list1.index(obj) 用于从列表中找出某个值第一个匹配项的索引位置,查找的对象。
    str = ['qb','abc','abkd','akakal','a']
    print(str)  # ['qb', 'abc', 'abkd', 'akakal', 'a']
    b = sorted(str, key=lambda x: len(x), reverse=True)
    print(b)  # ['akakal', 'abkd', 'abc', 'qb', 'a']  降序
    c = sorted(str, key=lambda x: len(x), reverse=False)
    print(c)  # ['a', 'qb', 'abc', 'abkd', 'akakal']  升序
    str.sort(key=len)
    print(str)  # ['a', 'qb', 'abc', 'abkd', 'akakal']  升序
    str.sort(key=len,reverse=True)
    print(str)  # ['akakal', 'abkd', 'abc', 'qb', 'a']  降序

    list2 = [1,2,9,3,5,4]
    list2.sort()
    print(list2)  # [1, 2, 3, 4, 5, 9]

    dic = {"name": 20, "age": 18, "city": 31, "lel": "1362626627"}
    # 按key 排序
    lis = sorted(dic.items(),key=lambda i:i[0],reverse=False)
    print(dict(lis))    # {'age': 18, 'city': 31, 'lel': '1362626627', 'name': 20}

2、 元组

tuple1 = (1,2,3,4)
元组运算符
运算符 表示
+ 元组合并
* 元组复制
x in (1,2,3) 元素是否存在在元组中,返回true或false
for x in (1,2,3): 迭代
元组内置函数
函数 表示
len(tuple1) 元组元素个数
max(tuple1) 返回元组中元素最大值
min(tuple1) 返回元组中元素最小值
tuple(seq) 将列表转化成元组,seq为列表

3、 字典

dict = {'key1': 'value1', 'key2': 'value2', 'key3': 'value2'}
函数&方法 表示
len(dict) 字典元素个数
str(dict) 以可打印的字符串表示
type(dict) 返回变量类型
dict.clear() 函数用于删除字典内所有元素, 无返回值
dict.copy() 返回一个字典的浅复制
dict.fromkeys(seq, value) 用于创建一个新字典,以序列 seq 中元素做字典的键,value 为字典所有键对应的初始值
dict.get(key, default=None) get() 函数返回指定键的值,如果值不在字典中返回默认值。
key in dict 字典 in 操作符用于判断键是否存在于字典中,如果键在字典 dict 里返回 true,否则返回 false。 not in 操作符刚好相反
dict.items() items() 方法以列表返回可遍历的(键, 值) 元组数组。
dict.keys() 字典 keys() 方法返回一个可迭代对象,可以使用 list(dict.keys()) 来转换为列表。Python2.x 是直接返回列表
dict.update(dict2) 字典 update() 函数把字典参数 dict2 的 key/value(键/值) 对更新到字典 dict 里。
dict.setdefault(key, default=None) 字典 setdefault() 方法和 get()方法 类似, 如果键不存在于字典中,将会添加键并将值设为默认值。
dict.values() 字典 values() 方法返回一个迭代器,可以使用 list(dict.values()) 来转换为列表,列表为字典中的所有值。
dict.pop(key) pop() 方法删除字典给定键 key 所对应的值,返回值为被删除的值。key值必须给出。 否则,返回default值。
    obj1 = {"key1":"hhh","key2":10}
    obj2 = {"key2": 2, "key4": "ccc"}
    obj1.update(obj2)
    print(obj1)    # {'key1': 'hhh', 'key2': 2, 'key4': 'ccc'}
    
    obj1 = {"key1":"hhh","key2":10}
    obj2 = {"key2": 2, "key4": "ccc"}
    final_obj = dict(obj1, **obj2)
    print(final_obj)  # {'key1': 'hhh', 'key2': 2, 'key4': 'ccc'}

 
    obj1 = {"key1":"hhh","key2":10}
    obj2 = {"key2": 2, "key4": "ccc"}
    res = {**obj1, **obj2}
    print(res)  # {'key1': 'hhh', 'key2': 2, 'key4': 'ccc'}

4、 集合

方法 表示
set.add(elmnt) 用于给集合添加元素,如果添加的元素在集合中已存在,则不执行任何操作。
set.clear() 用于移除集合中的所有元素,无返回值
set.copy() 用于拷贝一个集合
set1.difference(set2) 用于返回集合的差集,即返回的集合元素包含在第一个集合中,但不包含在第二个集合(方法的参数)中
set1.difference_update(set2) 用于移除两个集合中都存在的元素。difference_update() 方法与 difference() 方法的区别在于 difference() 方法返回一个移除相同元素的新集合,而 difference_update() 方法是直接在原来的集合中移除元素,没有返回值。
set1.isdisjoint(set2) 用于判断两个集合是否包含相同的元素,如果没有返回 True,否则返回 False。
set1.issubset(set2) 用于判断集合的所有元素是否都包含在指定集合中,如果是则返回True,否则返回 False。
set.issuperset(set) 用于判断指定集合的所有元素是否都包含在原始的集合中,如果是则返回 True,否则返回 False。
set.union(set1, set2...) 返回两个集合的并集,即包含了所有集合的元素,重复的元素只会出现一次。
set.update(set) 用于修改当前集合,可以添加新的元素或集合到当前集合中,如果添加的元素在集合中已存在,则该元素只会出现一次,重复的会忽略。
set.pop() 用于随机移除一个元素
set.remove(item) 用于移除集合中的指定元素,该方法不同于 discard() 方法,因为 remove() 方法在移除一个不存在的元素时会发生错误,而 discard() 方法不会。
set.discard(value) 用于移除指定的集合元素。
set.intersection(set1, set2 ... etc) 返回两个或更多集合中都包含的元素,即交集
set.intersection_update(set1, set2 ... etc) 用于获取两个或更多集合中都重叠的元素,即计算交集。 intersection_update() 方法不同于 intersection() 方法,因为 intersection() 方法是返回一个新的集合,而 intersection_update() 方法是在原始的集合上移除不重叠的元素。
    a = [1,2,4,5]
    b = [4,5,6,7]
    c = [i for i in a if i in b]
    print(c)  # [4,5]
    d = list(set(a).intersection(set(b)))
    print(d) # [4,5]
    e = list(set(a).union(set(b)))
    print(e) # [1,2,4,5,6,7]
    f = list(set(a).difference(set(b)))
    print(f) # [1,2]
    g = list(set(b).difference(set(a)))
    print(g) # [6,7]
上一篇下一篇

猜你喜欢

热点阅读