初識python

字符串

"hello world"
  • 萬惡的字符串拼接
python中的字符串在C語言中體現(xiàn)為是一個(gè)字符數(shù)組韧掩,每次創(chuàng)建字符串時(shí)候需要在內(nèi)存中開辟一塊連續(xù)的空間酪劫,
并且一旦需要修改字符串的話旱捧,就需要再次開辟空間愕够,萬惡的+號每出現(xiàn)一次就會在內(nèi)從中重新開辟一塊空間过咬。
  • 字符串格式化
name = "bear"
print "i am %s " % name

 # **輸出**
i am bear
  • 字符串常用功能
  • strip() # 去掉字符串首尾空格浦箱、換行符吸耿、tab
value = "     my name is bear     "
print(value.strip())  # 會將首尾的空格去掉
# 輸出
my name is bear
  • split() # 通過指定分隔符對字符串進(jìn)行切片,得到一個(gè)列表
names = "zhangsan, lisi, wangwu"
name2 = names.split(",")
print(name2)
# 輸出
['zhangsan', ' lisi', ' wangwu']
  • center() # 返回一個(gè)原字符串居中,并使用空格填充至長度 width 的新字符串酷窥。默認(rèn)填充字符為空格咽安。
例1:
value = "my name is bear"
print(value.center(50))
# 輸出
               my name is bear              
例2:
# 使用*填充空格
value = "my name is bear"
print(value.center(50, '*'))
# 輸出
  • find() # 字符串查找
例1:
# 在字符串value中查找字符串"zhangcong"是否存在,如果存在返回其下標(biāo)值
value = "my name is zhangbear"
print(value.find("zhang"))
# 輸出
11
-
例2:
# 指定開始的位置查找
value = "my name is zhangbear, my name is zhangbear"
print(value.find("zhang", 12))
# 輸出
33
  • capitalize() # 首字母大寫
value = "my name is bear, my name is bear"
print(value.capitalize())
# 輸出
My name is bear, my name is bear
  • upper() # 將字符串里面的所有字母都改為大寫
value = "43 fd"
print(value.upper())
# 輸出
43 FD
  • format() 格式化字符串
value = "my name is {}"
print(value.format("bear"))
# 輸出
my name is bear
  • isdigit() # 判斷字符串是否是數(shù)字類型 返回True 或 False
例1:
value = "my name is {}"
print(value.isdigit())
# 輸出
False
-
例2:
num_str = "1000"
print(num_str.isdigit())
# 輸出
True
  • isalnum() # 判斷字符是否只含有字母和數(shù)字組成 返回True 或 False
例1:
value = "43fd"
print(value.isalnum())
# 輸出
True
-
例2:
# value中包含一個(gè)空格
value = "43 fd"
print(value.isalnum())
# 輸出
False
  • endswith() # 匹配字符串的結(jié)束位置蓬推,返回True 或 False
value = "43 fd"
print(value.endswith("fd"))
# 輸出
True
-
print(value.endswith("c"))
# 輸出
False
  • startswith() # 匹配字符串的開始位置板乙,返回True 或 False
 value = "43 fd"
print(value.startswith("4"))
# 輸出
True
-
print(value.startswith("fda"))
# 輸出
False

列表

# 創(chuàng)建列表
name_list = ["zhangsan", "lisi", "wangwu"]
或
name_list = list(["zhangsan", "lisi", "wangwu"])
# 通過列表的下標(biāo)來取對應(yīng)的值
print(name_list[1])
# 輸出
lisi
  • 列表常用功能
  • 修改列表中的值
# 將name_list中的 "lisi" 修改為 "liwu"
name_list = ["zhangsan", "lisi", "wangwu"]
name_list[1] = "liwu"  # 指定下標(biāo)修改列表的值
print(name_list)
# 輸出
['zhangsan', 'liwu', 'wangwu']
  • 切片
# 輸出name_list中的第一個(gè)值和第二個(gè)值
name_list = ["zhangsan", "lisi", "wangwu", 1, 2, 3, 4, 5]
print(name_list[1:3])    # 顧頭不顧尾
# 輸出
['lisi', 'wangwu']
  • 步長
# 首先創(chuàng)建一個(gè)從0到100的列表,不包含100
num_list = list(range(100))
print(num_list[::2])
# 輸出
[0, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 
24, 26, 28, 30, 32, 34, 36, 38, 40, 42, 44, 
46, 48, 50, 52, 54, 56, 58, 60, 62, 64, 66, 
68, 70, 72, 74, 76, 78, 80, 82, 84, 86, 88, 
90, 92, 94, 96, 98]
# 注:通過步長可以取奇偶數(shù)
  • insert() # 指定坐標(biāo)插入值
# 在列表name_list的值"lisi"前面插入一個(gè)值"xiaogou"
name_list = ["zhangsan", "lisi", "wangwu"]
name_list.insert(1, "xiaogou")
print(name_list)
# 輸出
['zhangsan', 'xiaogou', 'lisi', 'wangwu']
  • append() # 在列表的末尾追加一個(gè)值
name_list = ["zhangsan", "lisi", "wangwu"]
name_list.append("xiaogou")
print(name_list)
# 輸出
['zhangsan', 'lisi', 'wangwu', 'xiaogou']
  • remove() # 刪除列表中的指定值
name_list = ["zhangsan", "lisi", "wangwu"]
name_list.remove("lisi")
print(name_list)
# 輸出
['zhangsan', 'wangwu']
# 如果刪除的值不在列表中,則會報(bào)錯(cuò)
name_list = ["zhangsan", "lisi", "wangwu"]
name_list.remove("lisfdi")
print(name_list)
# 輸出報(bào)錯(cuò)信息
ValueError: list.remove(x): x not in list
  • count() # 查找在列表中出現(xiàn)的次數(shù)
name_list = ["zhangsan", "lisi", "wangwu", "lisi", 1, 2, 3, 4, 5]
print(name_list.count("lisi"))  # 查找"lisi"在列表中出現(xiàn)的次數(shù)
# 輸出
2
  • index() # 查找在列表中的下標(biāo)
name_list = ["zhangsan", "lisi", "wangwu", "lisi", 1, 2, 3, 4, 5]
print(name_list.index("lisi"))
# 輸出
1
-
# 如果查找的值在列表中不存在募逞,則會報(bào)錯(cuò)
name_list = ["zhangsan", "lisi", "wangwu", "lisi", 1, 2, 3, 4, 5]
print(name_list.index("lisi2"))
# 輸出報(bào)錯(cuò)信息
ValueError: 'lisi2' is not in list
  • extend() # 在原先列表的基礎(chǔ)之上擴(kuò)展一個(gè)新的列表
name_list = ["zhangsan", "lisi", "wangwu", "lisi"]
name_list2 = [1, 2, 3, 4, 5]
name_list.extend(name_list2)
print(name_list)
# 輸出
['zhangsan', 'lisi', 'wangwu', 'lisi', 1, 2, 3, 4, 5]
  • reverse() # 將列表的值進(jìn)行反轉(zhuǎn)
name_list = ['zhangsan', 'lisi', 'wangwu', 'lisi', 1, 2, 3, 4, 5]
name_list.reverse()
print(name_list)
# 輸出
[5, 4, 3, 2, 1, 'lisi', 'wangwu', 'lisi', 'zhangsan']
  • sort() # 排序
name_list = ['zhangsan', 'lisi', 'wangwu', 'lisi', 1, 2, 3, 4, 5]
name_list.sort()
# 輸錯(cuò)報(bào)錯(cuò)信息
TypeError: unorderable types: int() < str()
-
# 對字母進(jìn)行排序
name_list = ['zhangsan', 'lisi', 'wangwu', 'lisi']
name_list.sort()
print(name_list)
# 輸出
['lisi', 'lisi', 'wangwu', 'zhangsan']
-
# 對數(shù)字進(jìn)行排序
num_list = [3, 4, 1, 100, 3, 5, 6]
num_list.sort()
print(num_list)
# 輸出
[1, 3, 3, 4, 5, 6, 100]
  • pop() # 默認(rèn)刪除列表最后的一個(gè)值蛋铆,并返回刪掉的那個(gè)值
name_list = ['zhangsan', 'lisi', 'wangwu', 'lisi', '44']
pop_name = name_list.pop()
print(name_list)
print(pop_name)
# 輸出
['zhangsan', 'lisi', 'wangwu', 'lisi']
44
-
# 指定下標(biāo)刪除列表元素
name_list = ['zhangsan', 'lisi', 'wangwu', 'lisi', '44']
pop_name = name_list.pop(2)
print(name_list)
print(pop_name)
# 輸出
['zhangsan', 'lisi', 'lisi', '44']
wangwu
  • copy() # 淺拷貝 可以通過id()查看內(nèi)存地址看區(qū)別
name_list = ['zhangsan', 'lisi', 'wangwu', 'lisi', '44']
name_list2 = name_list.copy()
print("name_list: %s" % name_list)
print("name_list2: %s" % name_list2)
# 將name_list中的'zhangsan'改為'liusan'
name_list[0] = 'liusan'
print("修改完之后")
print("name_list: %s" % name_list)
print("name_list2: %s" % name_list2)
# 輸出
name_list: ['zhangsan', 'lisi', 'wangwu', 'lisi', '44']
name_list2: ['zhangsan', 'lisi', 'wangwu', 'lisi', '44']
修改完之后
name_list: ['liusan', 'lisi', 'wangwu', 'lisi', '44']
name_list2: ['zhangsan', 'lisi', 'wangwu', 'lisi', '44']
-
# 在name_list中嵌套一個(gè)列表,然后拷貝一份放接,然后在修改嵌套列表中的值
name_list = ['zhangsan', 'lisi', 'wangwu', 'lisi', '44', [3, 4, 1, 100, 3, 5, 6]]
name_list2 = name_list.copy()
print("name_list: %s" % name_list)
print("name_list2: %s" % name_list2)
# 將name_list中的'zhangsan'改為'liusan'
name_list[-1][0] = 'liusan'
print("修改完之后")
print("name_list: %s" % name_list)
print("name_list2: %s" % name_list2)
# 輸出
# 可以看到name_list中嵌套列表中的值被修改刺啦,name_list2也隨著變化,淺拷貝只能操作第一層
name_list: ['zhangsan', 'lisi', 'wangwu', 'lisi', '44', [3, 4, 1, 100, 3, 5, 6]]
name_list2: ['zhangsan', 'lisi', 'wangwu', 'lisi', '44', [3, 4, 1, 100, 3, 5, 6]]
修改完之后
name_list: ['zhangsan', 'lisi', 'wangwu', 'lisi', '44', ['liusan', 4, 1, 100, 3, 5, 6]]
name_list2: ['zhangsan', 'lisi', 'wangwu', 'lisi', '44', ['liusan', 4, 1, 100, 3, 5, 6]]
# 淺拷貝與=之間的區(qū)別纠脾,等于號相當(dāng)于軟連接玛瘸,淺拷貝類似于上面

字典

  • 創(chuàng)建字典
創(chuàng)建字典

# 字典是以key和value的形式出現(xiàn)的
id_db = {
    22323232: {
        "name": "ShanPao",
        "age": 22,
        "addr": "ShanDong"
    },
    43267432:{
        "name": "DaShanPao",
        "age": 24,
        "addr": "DongBei"
    }
}
# 輸出字典中key為id_db[22323232]的值
print(id_db[22323232])
# 修改字典中key為22323232的key "name"的值
id_db[22323232]["name"] = "Wangwu"
print(id_db)
# 輸出
{'age': 22, 'addr': 'ShanDong', 'name': 'ShanPao'}
{22323232: {'age': 22, 'addr': 'ShanDong', 'name': 'Wangwu'}, 
43267432: {'age': 24, 'addr': 'DongBei', 'name': 'DaShanPao'}}
  • 字典常用功能
  • pop() # 對指定key進(jìn)行刪除,并返回其value
id_db = {
     22323232: {
       "name": "ShanPao",
       "age": 22,
       "addr": "ShanDong"
     },
     43267432:{
       "name": "DaShanPao",
       "age": 24,
       "addr": "DongBei"
     }
}
print(id_db)
v = id_db.pop(43267432)
print(v)
print(id_db)
# 輸出
# 字典id_db的值
{22323232: {'age': 22, 'addr': 'ShanDong', 'name': 'ShanPao'},
 43267432: {'age': 24, 'addr': 'DongBei', 'name': 'DaShanPao'}}
# 通過pop()刪除的值
{'age': 24, 'addr': 'DongBei', 'name': 'DaShanPao'}
# 通過pop()刪除之后的值
{22323232: {'age': 22, 'addr': 'ShanDong', 'name': 'ShanPao'}}
  • get() # 通過key獲取值
id_db = {
     22323232: {
       "name": "ShanPao",
       "age": 22,
       "addr": "ShanDong"
     },
     43267432:{
       "name": "DaShanPao",
       "age": 24,
       "addr": "DongBei"
     }
}
print(id_db.get(43267432))
# 輸出
{'age': 24, 'name': 'DaShanPao', 'addr': 'DongBei'}
  • update() # 對已經(jīng)存在的key進(jìn)行更新,沒有的key進(jìn)行添加
id_db = {
       22323232: {
           "name": "ShanPao",
           "age": 22,
           "addr": "ShanDong"
     },
       43267432:{
           "name": "DaShanPao",
           "age": 24,
           "addr": "DongBei"
     }
}
dic2 = {
       22323232: {
           "name": "DaShaXXXXXXX",
           "age": 22,
           "addr": "ShanDong"
     },
       "name": "acong",
       43267432: "xxxxxx"
   }
print(id_db)
id_db.update(dic2)
print(id_db)
# 輸出
{22323232: {'addr': 'ShanDong', 'name': 'ShanPao', 'age':  22}, 43267432: {'addr': 'DongBei', 'name': 'DaShanPao', 'age': 24}}
{22323232: {'addr': 'ShanDong', 'name': 'DaShaXXXXXXX', 'age': 22}, 43267432: 'xxxxxx', 'name': 'acong'}
  • items() # 將字典的key和value放到一個(gè)元組中苟蹈,多組key和value放入到到一個(gè)列表
    中糊渊,轉(zhuǎn)成這種格式: [(key, value), (key, value)]
id_db = {
       22323232: {
           "name": "ShanPao",
           "age": 22,
           "addr": "ShanDong"
     },
       43267432:{
           "name": "DaShanPao",
           "age": 24,
           "addr": "DongBei"
     }
}
print(id_db.items())
# 輸出
dict_items([(22323232, {'age': 22, 'addr': 'ShanDong', 'name': 'ShanPao'}), (43267432, {'age': 24, 'addr': 'DongBei', 'name': 'DaShanPao'})])
  • keys() # 輸出字典所有的key
id_db = {
       22323232: {
           "name": "ShanPao",
           "age": 22,
           "addr": "ShanDong"
     },
       43267432:{
           "name": "DaShanPao",
           "age": 24,
           "addr": "DongBei"
     }
}
print(id_db.keys())
# 輸出
dict_keys([22323232, 43267432])
  • values() # 輸出字典所有的value
id_db = {
      22323232: {
          "name": "ShanPao",
          "age": 22,
          "addr": "ShanDong"
    },
      43267432:{
          "name": "DaShanPao",
          "age": 24,
          "addr": "DongBei"
    }
}
print(id_db.values())
# 輸出
dict_values([{'name': 'ShanPao', 'addr': 'ShanDong', 'age': 22}, {'name': 'DaShanPao', 'addr': 'DongBei', 'age': 24}])
  • has_key() # python3使用in判斷

  • setdefault() # 指定一個(gè)key,如果字典存在這個(gè)key慧脱,則返回該key的值渺绒,否則創(chuàng)建這個(gè)key,如果setdefault()括號內(nèi)為空菱鸥,則創(chuàng)建的key的value 為None宗兼,否則為該括號內(nèi)填寫的值

id_db = {
       22323232: {
           "name": "ShanPao",
           "age": 22,
           "addr": "ShanDong"
     },
       43267432:{
           "name": "DaShanPao",
           "age": 24,
           "addr": "DongBei"
     }
    }
value = id_db.setdefault(43267432)
print(value)
value2 = id_db.setdefault(432674323232)
print(value2)
print(id_db)
# 輸出
{'addr': 'DongBei', 'name': 'DaShanPao', 'age': 24}
None
{22323232: {'addr': 'ShanDong', 'name': 'ShanPao', 'age': 22}, 43267432: {'addr': 'DongBei', 'name': 'DaShanPao', 'age': 24}, 432674323232: None}
  • popitem() # 隨機(jī)刪除字典中的指定的key
id_db = {
       22323232: {
           "name": "ShanPao",
           "age": 22,
           "addr": "ShanDong"
     },
       43267432:{
           "name": "DaShanPao",
           "age": 24,
           "addr": "DongBei"
     }
   }
print(id_db.popitem())
print(id_db)
# 輸出
(22323232, {'age': 22, 'addr': 'ShanDong', 'name': 'ShanPao'})
{43267432: {'age': 24, 'addr': 'DongBei', 'name': 'DaShanPao'}}

數(shù)據(jù)類型

  • 算數(shù)運(yùn)算


    image.png
  • 比較運(yùn)算


    image.png
  • 賦值運(yùn)算


    image.png
  • 邏輯運(yùn)算


    image.png
  • 成員運(yùn)算


    image.png
  • 身份運(yùn)算


    image.png
  • 位運(yùn)算


    image.png
  • 運(yùn)算符優(yōu)先級


    image.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市氮采,隨后出現(xiàn)的幾起案子殷绍,更是在濱河造成了極大的恐慌,老刑警劉巖鹊漠,帶你破解...
    沈念sama閱讀 211,042評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件主到,死亡現(xiàn)場離奇詭異,居然都是意外死亡躯概,警方通過查閱死者的電腦和手機(jī)镰烧,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評論 2 384
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來楞陷,“玉大人怔鳖,你說我怎么就攤上這事」潭辏” “怎么了结执?”我有些...
    開封第一講書人閱讀 156,674評論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長艾凯。 經(jīng)常有香客問我献幔,道長,這世上最難降的妖魔是什么趾诗? 我笑而不...
    開封第一講書人閱讀 56,340評論 1 283
  • 正文 為了忘掉前任蜡感,我火速辦了婚禮蹬蚁,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘郑兴。我一直安慰自己犀斋,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,404評論 5 384
  • 文/花漫 我一把揭開白布情连。 她就那樣靜靜地躺著叽粹,像睡著了一般。 火紅的嫁衣襯著肌膚如雪却舀。 梳的紋絲不亂的頭發(fā)上虫几,一...
    開封第一講書人閱讀 49,749評論 1 289
  • 那天,我揣著相機(jī)與錄音挽拔,去河邊找鬼辆脸。 笑死,一個(gè)胖子當(dāng)著我的面吹牛螃诅,可吹牛的內(nèi)容都是我干的啡氢。 我是一名探鬼主播,決...
    沈念sama閱讀 38,902評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼州刽,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了浪箭?” 一聲冷哼從身側(cè)響起穗椅,我...
    開封第一講書人閱讀 37,662評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎奶栖,沒想到半個(gè)月后匹表,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,110評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡宣鄙,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年袍镀,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片冻晤。...
    茶點(diǎn)故事閱讀 38,577評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡苇羡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出鼻弧,到底是詐尸還是另有隱情设江,我是刑警寧澤,帶...
    沈念sama閱讀 34,258評論 4 328
  • 正文 年R本政府宣布攘轩,位于F島的核電站叉存,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏度帮。R本人自食惡果不足惜歼捏,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,848評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧瞳秽,春花似錦瓣履、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至痰洒,卻和暖如春瓢棒,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背丘喻。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評論 1 264
  • 我被黑心中介騙來泰國打工脯宿, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人泉粉。 一個(gè)月前我還...
    沈念sama閱讀 46,271評論 2 360
  • 正文 我出身青樓连霉,卻偏偏與公主長得像,于是被迫代替她去往敵國和親嗡靡。 傳聞我的和親對象是個(gè)殘疾皇子解恰,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,452評論 2 348

推薦閱讀更多精彩內(nèi)容

  • 初識python基本數(shù)據(jù)類型 數(shù)字 int(整型) long(長整型) -- python3 中已經(jīng)將類型取消 f...
    _阿聰閱讀 450評論 0 1
  • 一蒋搜、快捷鍵 ctr+b 執(zhí)行ctr+/ 單行注釋ctr+c ...
    o_8319閱讀 5,793評論 2 16
  • ¥開啟¥ 【iAPP實(shí)現(xiàn)進(jìn)入界面執(zhí)行逐一顯】 〖2017-08-25 15:22:14〗 《//首先開一個(gè)線程,因...
    小菜c閱讀 6,365評論 0 17
  • 第十三章 小國寡民 安居樂業(yè) (原第80章) 小國寡民。 使有什伯之器而不用欺嗤; 使民重死而不遠(yuǎn)徙仗岖。 雖有舟輿蔓姚,無所...
    李明熱情似火閱讀 621評論 0 0
  • 2017.7.22 晴 瑣事記錄 一惕耕、昨晚老公微信問候我們∶圩裕可以感受到他的關(guān)心菩貌。 用了P.E.T跟老公說話后,我感...
    carol曉霞閱讀 194評論 0 0