Python快速精通2 - 序列,字典代碼部分

Python3基礎(chǔ)2:序列(列表,元組)與字典

(一)序列通用方法

序列封包

本質(zhì)上: 變量 < - - 元組
看下面例子:

companys = '華為','阿里','騰訊','智能天下'
print(type(companys))
print(companys)
<class 'tuple'>
('華為', '阿里', '騰訊', '智能天下')

序列解包

本質(zhì)上: 多個變量 < - - 序列 (列表,元組,字符串都屬于序列,一般是將列表和元組內(nèi)的元組直接賦值給變量)
將一個序列內(nèi)的元素賦值給多個變量

hw,ali,tecent,zntx= ('華為','阿里','騰訊','智能天下')
print(hw,ali)
華為 阿里

同時使用序列封包與解包

name,age,job,email = 'xiaobai',28,'engineer','xxx@163.com'
print(name,job)
xiaobai engineer

Python這樣做只是為了炫嗎? 例如我們要完成一個簡單的變量交換

x,y = 100,200
print('交換位置前: x = %d, y = %d' % (x,y))
x,y = y,x
print('交換位置后: x = %d, y = %d' % (x,y))
交換位置前: x = 100, y = 200
交換位置后: x = 200, y = 100

需求: 在數(shù)據(jù)庫表中取出一條記錄有N個字段,如果僅僅對前面某幾個字段感興趣,那么序列解包是不是沒有用處了?

key,name,age,job,*other = '0001','Jark',28,'enginer','BeijingChaoyang','xxx@163.com'
print(name)
print(type(other))
#還可以這樣
*other,email = '0001','Jark',28,'enginer','BeijingChaoyang','xxx@163.com'
print(email)
#還可以這樣
id,*middle,email = '0001','Jark',28,'enginer','BeijingChaoyang','xxx@163.com'
print(middle)
Jark
<class 'list'>
xxx@163.com
['Jark', 28, 'enginer', 'BeijingChaoyang']

(二)使用列表

2.1 創(chuàng)建列表

# 方式1: 中括號
companys = ['華為','阿里巴巴','騰訊','智能天下']
print('companys:',companys)


# 方式2: list函數(shù),將其它類型轉(zhuǎn)換成為列表
# 將range區(qū)間對象轉(zhuǎn)換為list
numbers = list(range(1,10))
print('numbers: %s' % numbers)
print('numbers的實例ID: {0}'.format(id(numbers))) #和后面切片得到的list對比ID
# 將字符串轉(zhuǎn)換為list(雖然沒什么意義,就是體驗list函數(shù)的作用)
strs = list('python')
print('strs: %s' % strs)
# 將tuple轉(zhuǎn)換為list
tpl = ('Java','Python','JavaScript','Scala','Go','R')
tpl_list = list(tpl)
print('tpl_list: %s' % tpl_list)


# 注意,對一個列表進行切片,也會產(chǎn)生一個新列表
sub_numbers = numbers[2:6]
#和前面切片得到的list對比ID
print('sub_numbers的實例ID: {id}'.format(id = id(sub_numbers)))

#注: 上面使用了多種字符串的格式化輸出方式,當做對三種字符串格式化方式進行復(fù)習(xí)
companys: ['華為', '阿里巴巴', '騰訊', '智能天下']
numbers: [1, 2, 3, 4, 5, 6, 7, 8, 9]
numbers的實例ID: 2014884805448
strs: ['p', 'y', 't', 'h', 'o', 'n']
tpl_list: ['Java', 'Python', 'JavaScript', 'Scala', 'Go', 'R']
sub_numbers的實例ID: 2014884873096

2.2 添加元素

方式1, append()函數(shù),追加一個元素到列表最后面

bigCompany = ['華為','谷歌']
facebook = 'Facebook'
bigCompany.append(facebook)
print('bigCompany: ',bigCompany)

# 注意: 上面是一個簡單數(shù)據(jù)類型,如果是一個集合數(shù)據(jù)結(jié)構(gòu),會出現(xiàn)什么情況呢?
bat = ['百度','阿里','騰訊']
bigCompany.append(bat)
# 這里會發(fā)現(xiàn),bat這個列表會作為一個元素,添加到 bigCompany里面,如果這不是你期望的,請看下一個extends()函數(shù)
print('bigCompany: ',bigCompany)   
bigCompany:  ['華為', '谷歌', 'Facebook']
bigCompany:  ['華為', '谷歌', 'Facebook', ['百度', '阿里', '騰訊']]

方式2, extend()函數(shù),將集合元素拆開追加到列表最后面

bigCompany = ['華為','谷歌']

bat = ['百度','阿里','騰訊']
bigCompany.extend(bat)
# 這下發(fā)現(xiàn),使用extend()函數(shù),會將集合中的每個元素作為單獨的元素插入列表
print('bigCompany: ',bigCompany)   

# 如果使用extend()函數(shù),追加的是一個字符串呢,看結(jié)果發(fā)現(xiàn),同樣被拆解了,這就是extend與append的不同
facebook = 'Facebook'
bigCompany.extend(facebook)
print('bigCompany: ',bigCompany)

bigCompany:  ['華為', '谷歌', '百度', '阿里', '騰訊']
bigCompany:  ['華為', '谷歌', '百度', '阿里', '騰訊', 'F', 'a', 'c', 'e', 'b', 'o', 'o', 'k']

方式3, insert()函數(shù),插入元素到列表中

bigCompany = ['華為','谷歌','百度','阿里','騰訊']
zntx = '智能天下'

# 把新成員插入到指定的索引位置上,例如插入到索引位置1上
bigCompany.insert(1,zntx)
print('bigCompany: ',bigCompany)

# 如果插入的是一個集合元素呢
bat = ['百度','阿里','騰訊']
bigCompany.insert(2,bat)
# 同append一樣是將集合作為一個整體放進去了
print('bigCompany',bigCompany)  

bigCompany:  ['華為', '智能天下', '谷歌', '百度', '阿里', '騰訊']
bigCompany ['華為', '智能天下', ['百度', '阿里', '騰訊'], '谷歌', '百度', '阿里', '騰訊']

2.3 刪除元素

方式1: del語句,根據(jù)索引刪除元素 (注意是語句,不是函數(shù),還可以刪掉一個變量)

bigCompany = ['華為','谷歌','百度','阿里','騰訊']
# 刪掉一個元素: 例如刪掉索引位置為2的元素:'百度'
del bigCompany[2]
print('bigCompany',bigCompany)

numbers = list(range(1,10))
print('numbers: ',numbers)
# 刪掉一個范圍的元素: 例如刪掉索引位置[0:5)這個區(qū)間的元素,是不包括索引位置5上的元素的
del numbers[0:5]
print('numbers: ',numbers)

del numbers
# print('numbers:',numbers)   #執(zhí)行會出現(xiàn)NameError
bigCompany ['華為', '谷歌', '阿里', '騰訊']
numbers:  [1, 2, 3, 4, 5, 6, 7, 8, 9]
numbers:  [6, 7, 8, 9]

方式2: remove()方法,根據(jù)元素值刪除元素(在list中從頭到尾找到指定元素,執(zhí)行刪除)

bigCompany = ['華為','谷歌','百度','阿里','騰訊','百度']
bigCompany.remove('百度')
print('bigCompany:',bigCompany)
bigCompany: ['華為', '谷歌', '阿里', '騰訊', '百度']

方式3: clear()方法,清空列表內(nèi)的所有元素

countries = ['日本','越南','土耳其','印度']
print('list_lenth:{len},\t countries:{countries}'.format(len = len(countries),countries = countries))
countries.clear()
print('list_lenth:{1},\t countries:{0}'.format(countries,len(countries)))
list_lenth:4,    countries:['日本', '越南', '土耳其', '印度']
list_lenth:0,    countries:[]

2.4 修改元素

列表的每一個元素相當于一個變量,直接使用索引對指定元素賦值

bigCompany = ['華為','谷歌','百度','阿里','騰訊','百度']

#對第4索引位置的元素修改
bigCompany[4] = '螞蟻金服'
print(bigCompany)

#對最后一個元素修改值
bigCompany[-1]='字節(jié)跳動'
print(bigCompany)

#對超出list位置上的元素修改試試
# bigCompany[6]='Microsoft' # IndexError: list assignment index out of range
['華為', '谷歌', '百度', '阿里', '螞蟻金服', '百度']
['華為', '谷歌', '百度', '阿里', '螞蟻金服', '字節(jié)跳動']
bigCompany = ['華為','谷歌','百度','百度','阿里','騰訊']
newCompany = ['螞蟻金服','字節(jié)跳動']

#對索引范圍為[2:4]的值進行修改
bigCompany[2:4] = newCompany
print(bigCompany)

#對索引范圍為[2:結(jié)束]的值進行修改
bigCompany = ['華為','谷歌','百度','百度','阿里','騰訊']
bigCompany[2:] = newCompany
print(bigCompany)

# 既然這樣,那么對切片范圍[2:3]位置進行修改試試
bigCompany = ['華為','谷歌','百度','百度','阿里','騰訊']
bigCompany[2:3] = newCompany
print(bigCompany)

#那么這樣是否可以實現(xiàn)任意位置的插入一個范圍的值呢?
bigCompany = ['華為','谷歌','百度','百度','阿里','騰訊']
bigCompany[2:2] = newCompany
print(bigCompany)
['華為', '谷歌', '螞蟻金服', '字節(jié)跳動', '阿里', '騰訊']
['華為', '谷歌', '螞蟻金服', '字節(jié)跳動']
['華為', '谷歌', '螞蟻金服', '字節(jié)跳動', '百度', '阿里', '騰訊']
['華為', '谷歌', '螞蟻金服', '字節(jié)跳動', '百度', '百度', '阿里', '騰訊']

2.5 其他列表方法

下面的明天補上

(三) 元組

(四)字典

3.1 創(chuàng)建字典

3.2 添加元素

3.3 刪除元素

3.4 修改元素

3.5 其他字典方法

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容