python修行之路(五 列表与字典)

学完了列表与元组,接下来是字符串的操作,一点一点抠,这个过程真的要沉得住气,不然很容易被零碎的概念搞得崩溃。

 

字符串

前言:对于字符串里面的方法,——X——类似这一种有两个下划线的方法是面向于内部的,用不了。

name.capitalize()  首字母大写

name.center(50,"-")    输出 ---------------------Alex Li----------------------(打印50个字符,不够的用---补齐)

name.count('lex') 统计 lex出现次数
name.encode()  将字符串编码成bytes格式
name.endswith("Li")  判断字符串是否以 Li结尾
 "Alex\tLi".expandtabs(10) 输出'Alex      Li', 将\t转换成多长的空格
 name.find('A')  查找A,找到返回其索引, 找不到返回-1

format :
    >>> msg = "my name is {}, and age is {}"
    >>> msg.format("alex",22)
    'my name is alex, and age is 22'
    >>> msg = "my name is {1}, and age is {0}"
    >>> msg.format("alex",22)
    'my name is 22, and age is alex'
    >>> msg = "my name is {name}, and age is {age}"
    >>> msg.format(age=22,name="ale")
    'my name is ale, and age is 22'
format_map
    >>> msg.format_map({'name':'alex','age':22})
    'my name is alex, and age is 22'


msg.index('a')  返回a所在字符串的索引
'9aA'.isalnum()   True

'9'.isdigit() 是否整数
name.isnumeric 
name.isprintable
name.isspace
name.istitle
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....wow!!!"
    >>> str.translate(trantab)
    'th3s 3s str3ng 2x1mpl2....w4w!!!'

 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)
'00000my name is {name}, and age is {age}'

 

>>> n4.ljust(40,"-")
'Hello 2orld-----------------------------'
>>> n4.rjust(40,"-")
'-----------------------------Hello 2orld'


>>> b="ddefdsdff_哈哈"
>>> b.isidentifier() #检测一段字符串可否被当作标志符,即是否符合变量命名规则
True

 

字典操作

字典一种key - value 的数据类型,使用就像我们上学用的字典,通过笔划、字母来查对应页的详细内容。

语法:

info = {

        'stu1101': "T1",

        'stu1102': "L2",

         'stu1103': "X3", }

print(info)

输出结果发现并没有按数字顺序,也没有按字母顺序排列。

print(info ["stu1101"])

输出的结果是T1

所以引出了

字典的特性:

  • dict是无序的
  • key必须是唯一的,so 天生去重

 

增加

info = {

        'stu1101': "T1",

        'stu1102': "L2",

         'stu1103': "X3", }

 

>>> info["stu1104"] = "C4"
>>> info {'stu1102': 'L2, 'stu1104': 'C2', 'stu1103': 'X3', 'stu1101': 'T1'}

 

修改

info = {

        'stu1101': "T1",

        'stu1102': "L2",

         'stu1103': "X3", }

info['stu1101'] = "t2"
>>> info

{'stu1102': '2', 'stu1103': 'X3', 'stu1101': 't2'}

 

删除

>>> info
{'stu1102': 'L2', 'stu1103': 'X3', 'stu1101': 'T1'}
>>> info.pop("stu1101") #标准删除姿势
此时删除的是T1
>>> info
{'stu1102': 'L2', 'stu1103': 'X3'}
>>> del info['stu1103'] #换个姿势删除
>>> info
{'stu1102': 'L2'}
>>>
>>>
>>>
>>> info = {'stu1102': 'L2', 'stu1103': 'X3'}
>>> info
{'stu1102': 'L2', 'stu1103': 'X3'} #随机删除
>>> info.popitem()
('stu1102', 'L2')
>>> info
{'stu1103': 'X3'}

 

查找

>>> info = {'stu1102': 'L2', 'stu1103': 'X3'}
>>>
>>> "stu1102" in info #标准用法
True
>>> info.get("stu1102")  #获取
'L2'
>>> info["stu1102"] #同上,但是看下面
'L2'
>>> info["stu1105"]  #如果一个key不存在,就报错,get不会,不存在只返回None
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
KeyError: 'stu1105'

 

多级字典嵌套及操作

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
['全部免费,真好,好人一生平安', '服务器在国外,慢,可以用爬虫爬下来']

 

更多内容

#values
>>> info.values()
dict_values(['L2', 'X3'])

#keys
>>> info.keys()
dict_keys(['stu1102', 'stu1103'])


#setdefault
>>> info.setdefault("stu1106","Alex")
'Alex'
>>> info
{'stu1102': 'L2', 'stu1103': 'X3', 'stu1106': 'Alex'}
>>> info.setdefault("stu1102","L2")
'L2'
>>> info
{'stu1102': 'L2', 'stu1103': 'X3', 'stu1106': 'Alex'}


#update
>>> info
{'stu1102': 'L2', 'stu1103': 'X3', 'stu1106': 'Alex'}
>>> b = {1:2,3:4, "stu1102":"L2"}
>>> info.update(b)
>>> info
{'stu1102': 'L2', 1: 2, 3: 4, 'stu1103': 'X3', 'stu1106': 'Alex'}

#items
info.items()
dict_items([('stu1102', 'L2'), (1, 2), (3, 4), ('stu1103', 'X3'), ('stu1106', 'Alex')])


#通过一个列表生成默认dict,有个没办法解释的坑,少用吧这个
>>> dict.fromkeys([1,2,3],'testd')
{1: 'testd', 2: 'testd', 3: 'testd'}

 

循环dict

#方法1
for key in info:
    print(key,info[key])

#方法2
for k,v in info.items(): #会先把dict转成list,数据里大时莫用
    print(k,v)

 

 

总结:在本阶段学习,小白的我感到了吃力,建议学习这部分的同学能够耐心总结,对学习有好处的。

posted @ 2017-05-02 18:00  当IT幸福来敲门  阅读(253)  评论(0编辑  收藏  举报