切片元組字典知識點

索引:

切片

循環遍歷的兩種方式

傳遞

元組

字典

查找

值 = 字典[鍵]

1,字典.get(鍵,[默認值])

2,len(字典)計算字典元素個數,即鍵的總數

3,str(字典)輸出字典可打印的字符串表示

4,dict.keys()以列表返回一個字典所有的鍵

5,dict.values()以列表返回一個字典所有的值

6,dict.items()? ? ? ? ? ? ? ? 以列表返回可遍歷的(鍵, 值) 元組數組

修改和新增

字典[鍵]=值

刪除

字典.pop(鍵)

del 字典[鍵]

字典.clear()

遍歷字典的方法

1,dict.items()

2,根據“值 = 字典[鍵]”直接輸出

3,根據字典的每一項(即每一個鍵值對)都是一個列表,遍歷每個列表,然后輸出

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假裝這不是分割線&&&&&&&&&&&&&&&&&&&&')

正文

列表切片

import math ls=[float('%0.3f'%math.sqrt(i)) for i in range(0,10) ]

print(ls)

切片

ls[a:b:c]

a默認=0

b默認=len(ls)

c默認=1

&*&*&*&**&*&*&*

c=-1時,就是倒序的ls例:ls[::-1]? <==>? ? ls.reverse()

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假裝這不是分割線&&&&&&&&&&&&&&&&&&&&')

循環遍歷的兩種方式:

一、用while循環ls=[i**2 for i in range(0,19)]j=0while ja=20

print(b)? ==>b=10

ls1=[i for i in range(0,19)]

ls2=ls1

ls1.append(1)

print(ls1)? ==>ls1=[i for i in range(0,19)]+[1]

print(ls2)? ==>ls2=[i for i in range(0,19)]+[1]

傳遞后,一方改變,對另一方的影響:

1,如果是普通類型(數字、字符串、布爾、空),

另一方不受影響? ? ==>值傳遞

2,如果是非普通類型,

另一方會隨之改變? ==>引用傳遞

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假裝這不是分割線&&&&&&&&&&&&&&&&&&&&')

元組

元組是一個特殊的列表。只讀,不能修改。

一旦定義并賦值之后,不能再修改了。

只有查詢的功能

需要注意的兩點:

一,單元素元組的寫法

tu1=(1,)和tu2=(1)的格式不一樣,type(tu1)是tuple,type(tu2)是int

如果元組只有一個值,需要后面加逗號。

建議:

元組、列表,最后都加一個逗號

二,若元組中元素為列表時,

列表里面的內容可以更改

例:

nums = (1,2,3,[44,55,66])

nums[3][1] = 555

print(nums)? ==>nums=(1, 2, 3, [44, 555, 66])

反例:

nums = (1,2,3,[44,55,66])

nums[3] = [44,55,66]

這個操作則無法運行,如同:

ls1=[i for i in range(0,19)]

ls2=ls1

ls1=[i for i in range(0,9)]

print(ls1)==>ls1=[i for i in range(0,9)]

print(ls2)==>ls2=[i for i in range(0,9)]

違背了傳遞的總結的結論,

原因都是變量改變了地址導致

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假裝這不是分割線&&&&&&&&&&&&&&&&&&&&')

列表和元組相互轉換

列表 = list(元組)

元組轉列表

元組 = tuple(列表)

列表轉元組

&*&*&*&

列表可以直接[i for i in range(0,9)]

用范圍值定義,元組不可以這樣

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假裝這不是分割線&&&&&&&&&&&&&&&&&&&&')

字典

Python內置了字典:dict的支持,dict全稱dictionary

語法:

標識符 = {'鍵1':值1,'鍵1':值2...}

注意:

1、鍵必須是字符串,值是任何類型的

2、鍵必須是唯一的,值可以重復

3、如果鍵重復了,后面會覆蓋前面的

infos = {

'sid':110,

'sname':'老王',

'age':22,

'hobby':['抽煙','喝酒','燙頭發']

}

print(infos['sname'])

print(infos['hobby'][2])

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假裝這不是分割線&&&&&&&&&&&&&&&&&&&&')

查找

字典的鍵是無序的

值 = 字典[鍵] 根據鍵查詢值

1,字典.get(鍵,[默認值])

通過dict提供的get方法,如果key不存在,可以返回None,或者自己指定的value

2,len(字典) 計算字典元素個數,即鍵的總數。

3,str(字典) 輸出字典可打印的字符串表示。

4,dict.keys() 以列表返回一個字典所有的鍵

5,dict.values() 以列表返回一個字典所有的值

6,dict.items() 以列表返回可遍歷的(鍵, 值) 元組數組

#獲取所有的鍵

keys1 = infos.keys()

print(keys1)? ==>輸出結果為列表形式

即:

print(keys1)? ==>dict_keys(['hobby', 'age', 'sid', 'sname'])

#遍歷鍵

for i in keys1:

print(i)

#獲取所有的值

values1 = infos.values()

print(values1)? ==>輸出結果為列表形式

即:dict_values([110, 22, '老王', ['抽煙', '喝酒', '燙頭發']])

#遍歷值

for i in values1:

print(i)

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假裝這不是分割線&&&&&&&&&&&&&&&&&&&&')

修改和新增

如果存在這樣的鍵,是修改

否則是新增

infos = {

'sid':110,

'sname':'老王',

'age':22,

'hobby':['抽煙','喝酒','燙頭發']

}

#修改

infos['age'] = 99

print(infos)

#新增

infos['sex'] = '男'

print(infos)

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假裝這不是分割線&&&&&&&&&&&&&&&&&&&&')

刪除

字典.pop(鍵)

根據鍵,刪除指定的值,并將此值放回

del 字典[鍵]

根據鍵,刪除指定的值

字典.clear()

清空字典里的鍵值對

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假裝這不是分割線&&&&&&&&&&&&&&&&&&&&')

判斷某個鍵是不是在字典里面

語法:鍵 in 字典

如果鍵在字典中存在,返回True

否則,返回False

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假裝這不是分割線&&&&&&&&&&&&&&&&&&&&')

遍歷字典的方法

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假裝這不是分割線&&&&&&&&&&&&&&&&&&&&')

第一種:

print(infos.items())

輸出結果為:

dict_items([('sid', 110), ('hobby', ['抽煙', '喝酒', '燙頭發']), ('sname', '老王'), ('age', 22)])

這樣只是把字典打印出來,顯得很亂

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假裝這不是分割線&&&&&&&&&&&&&&&&&&&&')

第二種:

原理:根據“值 = 字典[鍵]”

for k in infos:

print('%s:%s'%(k,infos[k]))

輸出結果:

hobby:['抽煙', '喝酒', '燙頭發']

age:22

sid:110

sname:老王

簡單明了

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假裝這不是分割線&&&&&&&&&&&&&&&&&&&&')

第三種:用for遍歷列表的方法,

原理:字典的每一項(即每一個鍵值對)都是一個列表

infos_items=字典的每個鍵值對

for i in infos_items:

#print('i=%s'%str(i))

key = i[0]

value = i[1]

print('%s:%s'%(key,value))

輸出結果:

sid:110

age:22

hobby:['抽煙', '喝酒', '燙頭發']

sname:老王

不如第二種方法簡便

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,362評論 6 544
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,577評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,486評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,852評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,600評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,944評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,944評論 3 447
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,108評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,652評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,385評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,616評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,111評論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,798評論 3 350
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,205評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,537評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,334評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,570評論 2 379

推薦閱讀更多精彩內容