摘要:對于,就不能進(jìn)行字符的追加。與類似,也是對元素的增加。注意兩點(diǎn)如果正確刪除,不會有任何反饋。沒有消息就是好消息。是一個有意思的東西,內(nèi)涵豐富。并且可能會做一個有意思的游戲。
現(xiàn)在是講lis的第三章了。俗話說,事不過三,不知道在開頭,我也不知道這一講是不是能夠把基礎(chǔ)的list知識講完呢。哈哈。其實(shí)如果真正寫文章,會在寫完之后把這句話刪掉的。而我則是完全像跟看官聊天一樣,就不刪除了。
繼續(xù)。
對list的操作 向list中插入一個元素前面有一個向list中追加元素的方法,那個追加是且只能是將新元素添加在list的最后一個。如:
>>> all_users = ["qiwsir","github"] >>> all_users.append("io") >>> all_users ["qiwsir", "github", "io"]
從這個操作,就可以說明list是可以隨時改變的。這種改變的含義只它的大小即所容納元素的個數(shù)以及元素內(nèi)容,可以隨時直接修改,而不用進(jìn)行轉(zhuǎn)換。這和str有著很大的不同。對于str,就不能進(jìn)行字符的追加。請看官要注意比較,這也是str和list的重要區(qū)別。
與list.append(x)類似,list.insert(i,x)也是對list元素的增加。只不過是可以在任何位置增加一個元素。
我特別引導(dǎo)列為看官要通過官方文檔來理解:
list.insert(i, x)
Insert an item at a given position. The first argument is the index of the element before which to insert, so a.insert(0, x) inserts at the front of the list, and a.insert(len(a), x) is equivalent to a.append(x).
這次就不翻譯了。如果看不懂英語,怎么了解貴國呢?一定要硬著頭皮看英語,不僅能夠?qū)W好程序,更能...(此處省略兩千字)
根據(jù)官方文檔的說明,我們做下面的實(shí)驗(yàn),請看官從實(shí)驗(yàn)中理解:
>>> all_users ["qiwsir", "github", "io"] >>> all_users.insert("python") #list.insert(i,x),要求有兩個參數(shù),少了就報錯 Traceback (most recent call last): File "", line 1, in TypeError: insert() takes exactly 2 arguments (1 given) >>> all_users.insert(0,"python") >>> all_users ["python", "qiwsir", "github", "io"] >>> all_users.insert(1,"http://") >>> all_users ["python", "http://", "qiwsir", "github", "io"] >>> length = len(all_users) >>> length 5 >>> all_users.insert(length,"algorithm") >>> all_users ["python", "http://", "qiwsir", "github", "io", "algorithm"]
小結(jié):
list.insert(i,x),將新的元素x 插入到原list中的list[i]前面
如果i==len(list),意思是在后面追加,就等同于list.append(x)
刪除list中的元素list中的元素,不僅能增加,還能被刪除。刪除list元素的方法有兩個,它們分別是:
list.remove(x)
Remove the first item from the list whose value is x. It is an error if there is no such item.
list.pop([i])
Remove the item at the given position in the list, and return it. If no index is specified, a.pop() removes and returns the last item in the list. (The square brackets around the i in the method signature denote that the parameter is optional, not that you should type square brackets at that position. You will see this notation frequently in the Python Library Reference.)
我這里講授python,有一個習(xí)慣,就是用學(xué)習(xí)物理的方法。如果看官當(dāng)初物理沒有學(xué)好,那么一定是沒有用這種方法,或者你的老師沒有用這種教學(xué)法。這種方法就是:自己先實(shí)驗(yàn),然后總結(jié)規(guī)律。
先實(shí)驗(yàn)list.remove(x),注意看上面的描述。這是一個能夠刪除list元素的方法,同時上面說明告訴我們,如果x沒有在list中,會報錯。
>>> all_users ["python", "http://", "qiwsir", "github", "io", "algorithm"] >>> all_users.remove("http://") >>> all_users #的確是把"http://"刪除了 ["python", "qiwsir", "github", "io", "algorithm"] >>> all_users.remove("tianchao") #原list中沒有“tianchao”,要刪除,就報錯。 Traceback (most recent call last): File "", line 1, in ValueError: list.remove(x): x not in list
注意兩點(diǎn):
如果正確刪除,不會有任何反饋。沒有消息就是好消息。
如果所刪除的內(nèi)容不在list中,就報錯。注意閱讀報錯信息:x not in list
看官是不是想到一個問題?如果能夠在刪除之前,先判斷一下這個元素是不是在list中,在就刪,不在就不刪,不是更智能嗎?
如果看官想到這里,就是在編程的旅程上一進(jìn)步。python的確讓我們這么做。
>>> all_users ["python", "qiwsir", "github", "io", "algorithm"] >>> "python" in all_users #這里用in來判斷一個元素是否在list中,在則返回True,否則返回False True >>> if "python" in all_users: ... all_users.remove("python") ... print all_users ... else: ... print ""python" is not in all_users" ... ["qiwsir", "github", "io", "algorithm"] #刪除了"python"元素 >>> if "python" in all_users: ... all_users.remove("python") ... print all_users ... else: ... print ""python" is not in all_users" ... "python" is not in all_users #因?yàn)橐呀?jīng)刪除了,所以就沒有了。
上述代碼,就是兩段小程序,我是在交互模式中運(yùn)行的,相當(dāng)于小實(shí)驗(yàn)。
另外一個刪除list.pop([i])會怎么樣呢?看看文檔,做做實(shí)驗(yàn)。
>>> all_users ["qiwsir", "github", "io", "algorithm"] >>> all_users.pop() #list.pop([i]),圓括號里面是[i],表示這個序號是可選的 "algorithm" #如果不寫,就如同這個操作,默認(rèn)刪除最后一個,并且將該結(jié)果返回 >>> all_users ["qiwsir", "github", "io"] >>> all_users.pop(1) #指定刪除編號為1的元素"github" "github" >>> all_users ["qiwsir", "io"] >>> all_users.pop() "io" >>> all_users #只有一個元素了,該元素編號是0 ["qiwsir"] >>> all_users.pop(1) #但是非要刪除編號為1的元素,結(jié)果報錯。注意看報錯信息 Traceback (most recent call last): File "", line 1, in IndexError: pop index out of range #刪除索引超出范圍,就是1不在list的編號范圍之內(nèi)
給看官留下一個思考題,如果要向前面那樣,能不能事先判斷一下要刪除的編號是不是在list的長度范圍(用len(list)獲取長度)以內(nèi)?然后進(jìn)行刪除或者不刪除操作。
list是一個有意思的東西,內(nèi)涵豐富??磥硐乱恢v還要繼續(xù)講list。并且可能會做一個有意思的游戲。請期待。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://www.ezyhdfw.cn/yun/45292.html
摘要:對的操作合并有容乃大的中,對的操作提到了,也就是將某個元素追加到已知的一個后邊。如果的對象是數(shù)值型,則報錯。依然是上一條官方解釋是不是說的非常清楚明白了先到這里,下講還繼續(xù)有容乃大的 對list的操作 合并list 《有容乃大的list(1)》中,對list的操作提到了list.append(x),也就是將某個元素x 追加到已知的一個list后邊。 除了將元素追加到list中,還...
摘要:定義在中,用方括號表示一個,在方括號里面,可以是,也可以是類型的數(shù)據(jù),甚至也能夠是這種布爾值。前面在對進(jìn)行操作的時候,有一些內(nèi)置函數(shù),比如,這是去掉左右空格的內(nèi)置函數(shù),也是的方法。 前面的學(xué)習(xí)中,我們已經(jīng)知道了兩種python的數(shù)據(jù)類型:int和str。再強(qiáng)調(diào)一下對數(shù)據(jù)類型的理解,這個世界是由數(shù)據(jù)組成的,數(shù)據(jù)可能是數(shù)字(注意,別搞混了,數(shù)字和數(shù)據(jù)是有區(qū)別的),也可能是文字、或者是聲音、...
摘要:要研究清楚一些函數(shù)特別是內(nèi)置函數(shù)的功能,建議看官首先要明白內(nèi)置函數(shù)名稱的含義。前面提到的內(nèi)置函數(shù)得到的結(jié)果,就是一個排好序的。至此,有關(guān)的基本操作的內(nèi)置函數(shù),就差不多了。 list的話題的確不少,而且,在編程中,用途也非常多。 有看官可能要問了,如果要生成一個list,除了要把元素一個一個寫上之外,有沒有能夠讓計(jì)算機(jī)自己按照某個規(guī)律生成list的方法呢? 如果你提出了這個問題,充分...
摘要:不管是還是,所發(fā)起的循環(huán),在編程中是經(jīng)常被用到的。這里重點(diǎn)是復(fù)習(xí)并展示一下它的循環(huán)中,做為計(jì)數(shù)器的使用。通過上述實(shí)例,主要是讓看官理解在循環(huán)中計(jì)數(shù)器的作用。是用于并行遍歷的函數(shù)。一種方法是通過循環(huán),分別從兩個中取出元素,然后求和。 不管是while還是for,所發(fā)起的循環(huán),在python編程中是經(jīng)常被用到的。特別是for,一般認(rèn)為,它要比while快,而且也容易寫(是否容易,可能因人而...
摘要:有的前面有空格,有的后面有空格去掉元素前后的空格這是一個有意思的內(nèi)置函數(shù),本來我們可以通過的方式得到一個的每個元素編號,然后在用的方式得到該元素。 對于list,由于她的確非常非常龐雜,在python中應(yīng)用非常廣泛,所以,雖然已經(jīng)介紹完畢了基礎(chǔ)內(nèi)容,這里還要用一講深入一點(diǎn)點(diǎn),往往越深入越... list解析 先看下面的例子,這個例子是想得到1到9的每個整數(shù)的平方,并且將結(jié)果放在li...
閱讀 1503·2021-09-02 10:19
閱讀 1180·2019-08-26 13:25
閱讀 2188·2019-08-26 11:37
閱讀 2510·2019-08-26 10:18
閱讀 2758·2019-08-23 16:43
閱讀 3205·2019-08-23 16:25
閱讀 870·2019-08-23 15:53
閱讀 3439·2019-08-23 15:11