成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Python基礎之(二)字符串_列表_元組

asoren / 785人閱讀

摘要:字符串在中,萬物皆對象,顯然字符串是對象類型,用表示。其二是聲明為原始字符串如,由開頭引起的字符串就是聲明了后面引號里的東西是原始字符串,在里面放任何字符都表示該字符的原始含義,不需要再用轉義符了。

Python字符串

在Python中,萬物皆對象,顯然字符串是對象類型,用str表示。字符串類型通常用單引號或者雙引號包裹起來。

>>> "Hello,world"
"Hello,world"
>>> "Hello,world"
"Hello,world"
>>> type("Hello,world")

>>> 
變量和字符串

在Python中變量無類型,對象有類型

>>> b = "hello,world"
>>> b
"hello,world"

>>> print b
hello,world

>>> type(b)

連接字符串
>>> "py" + "thon"
"python"
>>> 

>>> a = 1989
>>> b = "free"
>>> print a + b

Traceback (most recent call last):
  File "", line 1, in 
    print a + b
TypeError: unsupported operand type(s) for +: "int" and "str"

>>> print b + `a` #反引號將整數(shù)a轉化為字符串
free1989
>>> 

用“+”拼接起來的字符串的兩個對象必須是同一類型的。如果是數(shù)字則是求和,如果是字符串則得到一個新的字符串。

還有其他兩種方法可以將整數(shù)轉化為字符串:

str():將整數(shù)對象轉換為字符串對象

>>> print b + str(a)
free1989

repr():相當于反引號``

>>> print b + repr(a)
free1989

int():將字符串對象轉換為整數(shù)對象

>>> a = "250"
>>> b = int(a)
>>> b
250
>>> type(b)

>>> 
轉義字符

在字符串中,總會有一些特殊的符號,就需要用轉義符。所謂轉義,就是不采用符號本來的含義,而采用另外一含義。下面表格中列出常用的轉義符:

轉義字符 描述
(在行尾時) 續(xù)行符
反斜杠符號
" 單引號
" 雙引號
a 響鈴
b 退格(Backspace)
e 轉義
000
n 換行
v 縱向制表符
t 橫向制表符
r 回車
f 換頁
oyy 八進制數(shù),yy代表的字符,例如:o12代表換行
xyy 十六進制數(shù),yy代表的字符,例如:x0a代表換行
other 其它的字符以普通格式輸出
原始字符串

用轉義符能夠讓字符串中的某些符號表示原來的含義,而不是被解析成某種具有特別能力的符號。下面看看這個代碼:

>>> dos = "c:
ews"
>>> dos
"c:
ews"
>>> print dos #當用print打印時就出現(xiàn)問題了
c:
ews

如何避免上述代碼的問題?有兩種方法,其一是前面介紹的轉義符解決。

>>> dos = "c:
ews"
>>> print dos
c:
ews
>>> 

其二是聲明為原始字符串

>>> dos = r"c:
ews"
>>> print dos
c:
ews
>>> dos = r"c:
ewspython"
>>> print dos
c:
ewspython

r"c:news",由r開頭引起的字符串就是聲明了后面引號里的東西是原始字符串,在里面放任何字符都表示該字符的原始含義,不需要再用轉義符了。

raw_input和print

下面實現(xiàn)接收和打印用戶通過鍵盤輸入的內(nèi)容:

不過在寫這個功能前,要了解函數(shù):

Python 2:raw_input()

Python 3: input()

這是Python的內(nèi)建函數(shù)(built-in function)。關于內(nèi)建函數(shù),可以分別通過下面的鏈接查看:

Python 2的內(nèi)建函數(shù)

Python 3的內(nèi)建函數(shù)

關于Python的內(nèi)建函數(shù),下面列出來,供參考:

abs()    divmod()    input()    open()    staticmethod()
all()    enumerate()    int()    ord()    str()
any()    eval()    isinstance()    pow()    sum()
basestring()    execfile()    issubclass()    print()    super()
bin()    file()    iter()    property()    tuple()
bool()    filter()    len()    range()    type()
bytearray()    float()    list()    raw_input()    unichr()
callable()    format()    locals()    reduce()    unicode()
chr()    frozenset()    long()    reload()    vars()
classmethod()    getattr()    map()    repr()    xrange()
cmp()    globals()    max()    reversed()    zip()
compile()    hasattr()    memoryview()    round()    __import__()
complex()    hash()    min()    set()    
delattr()    help()    next()    setattr()    
dict()    hex()    object()    slice()    
dir()    id()    oct()    sorted()

怎么才能知道哪個函數(shù)怎么用,并且用來干什么的呢?

help(abs)命令

Python的官網(wǎng)https://docs.python.org/2/library/functions.html

raw_input

>>> raw_input("input your name: ")
input your name: michael
"michael"
>>> name = raw_input("input your name: ")
input your name: michael
>>> name
"michael"
>>> type name
SyntaxError: invalid syntax
>>> type(name)

>>> age = raw_input("How old are you? ");
How old are you? 25  #輸入數(shù)字
>>> age
"25"
>>> type(age)
  #返回仍是str類型

print

>>> print "Hello, world"
Hello, world
>>> a = "python"
>>> print a
python
>>> b = "good"
>>> print a,b
python good
>>> 

特別提醒的是,print的返回值默認是以n結尾的,所以每個輸出語句之后自動換行。

索引和切片 索引

在Python中,把像字符串這樣的對象類型統(tǒng)稱為序列,顧名思義,序列就是有序排列。在這個序列中,每個人都有編號,編號和每個字符一一對應,在Python中這些編號稱為索引

>>> lang = "study python"
>>> lang[0]
"s"
>>> lang[1]
"t"

也可以這樣做:

>>> "study python"[0]
"s"
>>> "study python"[1]
"t"
>>> 

通過字符找到其在字符串中的索引值:

>>> lang = "study python"
>>> lang.index("p")
6
>>> lang.in
SyntaxError: invalid syntax
>>> lang.index("y")
4
切片

不管是得到一個字符還是多個字符,通過索引得到字符的過程稱為切片。

>>> lang = "study python"

>>> lang[2:9] #得到從2號到9號之間的字符串(包括2號但不包括9號)
"udy pyt"
>>> b = lang[1:] #得到從1號到最末尾的字符
>>> b
"tudy python"
>>> c = lang[:] #得到所有的字符
>>> c
"study python"
>>> d = lang[:10] #得到從0到10號之前的字符
>>> d
"study pyth"
>>> lang[1:12] 
"tudy python"
>>> lang[0:13] #如果第二個數(shù)字的長度大于字符串的長度,得到的返回結果就自動到最大長度終止,但是這種獲得切片的方法是值得提倡的。特別是如果在循環(huán)中,這樣做很可能會遇到麻煩。
"study python"
>>> lang[0:14]
"study python

如果在切片的時候,冒號左右都不寫數(shù)字,就是前面所操作的c = lang[:],其結果是變量的值c與源字符串lang一樣,即復制了一份,那是不是真的復制呢?下面的方式檢驗一下:

>>> id(c)
44841944
>>> id(lang)
44841944

從上面可以看出,兩個內(nèi)存地址一樣,說明c和lang兩個變量指向的是同一個對象。用c = lang[:]的方式并沒有生成一個新的字符串,而是將變量c這個標簽頁貼在原來那個字符串上了。

>>> lang = "study python"
>>> c = lang
>>> id(c)
50456160
>>> id(lang)
50456160

上述這種情況,變量c和lang也指向同一個對象。

基本操作

所有序列都有如下操作,字符串是序列的子集。

len():返回序列長度

+:連接兩個序列

*:重復序列元素

in: 判斷元素是否存在于序列中

max():返回最大值

min():返回最小值

cmp(str1,str2): 比較兩個序列值是否相同

"+"連接字符串
>>> str1 = "study"
>>> str2 = "python"
>>> str1 + str2
"studypython"
>>> str1 + "-->" + str2
"study-->python"
in

in用來判斷某個字符串是不是在另外一個字符串內(nèi),或者判斷某個字符串內(nèi)是否包含某個字符串,包含則返回True,否則返回false。

>>> str = "study python"
>>> "s" in str
True
>>> "i" in str
False
>>> "su" in str
False
>>> "stu" in str
True
>>> 
max()

str = "python"
max(str)

"y"

min()
>>> str = "python"
"y"
>>> min(str)
"h"
cmp()

將兩個字符串進行比較,首先將字符串中的符號轉化為對應的數(shù)字,然后再比較

如果返回的數(shù)值小于0,說明前者小于后者

等于0,表示兩者相等

大于0,表示前者大于后者

>>> cmp("aaa","abc")  #
-1
>>> cmp("abc","aaa");
1
>>> cmp("abc","abc");
0
>>> ord("a") #返回字符的ASCII值
97
>>> chr(97)  #返回ASCII值所對應的字符
"a"
"*"

以指定的次數(shù)重復打印字符串

>>> str = "python"
>>> str * 4
"pythonpythonpythonpython"
>>> print "-" * 20
--------------------
len()

len()返回字符串的長度,返回值類型是int型

>>> a = "hello"
>>> m = len(a)
>>> m
5
>>> type(m)

>>> 
常用的字符串方法

字符串的方法有很多,可以通過dir來查看:

>>> dir(str)
["__add__", "__class__", "__contains__", "__delattr__", "__doc__", "__eq__", "__format__", "__ge__", "__getattribute__", "__getitem__", "__getnewargs__", "__getslice__", "__gt__", "__hash__", "__init__", "__le__", "__len__", "__lt__", "__mod__", "__mul__", "__ne__", "__new__", "__reduce__", "__reduce_ex__", "__repr__", "__rmod__", "__rmul__", "__setattr__", "__sizeof__", "__str__", "__subclasshook__", "_formatter_field_name_split", "_formatter_parser", "capitalize", "center", "count", "decode", "encode", "endswith", "expandtabs", "find", "format", "index", "isalnum", "isalpha", "isdigit", "islower", "isspace", "istitle", "isupper", "join", "ljust", "lower", "lstrip", "partition", "replace", "rfind", "rindex", "rjust", "rpartition", "rsplit", "rstrip", "split", "splitlines", "startswith", "strip", "swapcase", "title", "translate", "upper", "zfill"]
判斷字符串是否全是字母
>>> "python".isalpha()  #字符串全是字母,返回TRUE
True
>>> "2python".isalpha() #字符串含有非字母,返回FALSE
False
>>> 
分割字符串

split()作用是將字符串根據(jù)某個分隔符進行分割。

>>> str = "I love Beijing"
>>> str.split(" ")
["I", "love", "Beijing"]  #返回值為名叫列表(list)的類型
>>> str = "www.baidu.com"
>>> str.split(",")
["www", "baidu", "com"]
>>> 
去掉字符串兩頭的空格
>>> str = "  python  "
>>> str.strip()  #去掉字符串左右空格
"python"
>>> str.lstrip() #去掉字符串左邊空格
"python  "
>>> str.rstrip() #去掉字符串右邊空格
"  python"
>>> 
字符大小寫轉換
>>> str = "pyThon" 
>>> str.upper() #將小寫字母完全變?yōu)榇髮懽帜?"PYTHON"
>>> str.lower() #將大寫字母完全變成小寫字母
"python"

>>> str.isupper() #判斷是否全是大寫字母
False
>>> str.islower() #判斷是否全是小寫字母
False
>>> str = "this is book"
>>> str.capitalize() #把所有單詞的第一個字母轉化為小寫字母
"This is book"
>>> str.istitle() #判斷每個單詞的第一個字母是否為大寫字母
False
>>> 
join連接字符串
>>> b = "www.baidu.com"
>>> c = b.split(".")
>>> c
["www", "baidu", "com"]
>>> ".".join(c)
"www.baidu.com"
>>> "**".join(c)
"www**baidu**com"
字符串格式化輸出 使用占位符
>>> "I like %s" % "Python" #%s表示字符串
"I like Python"
>>> "%d years old" % 25 #%d表示整數(shù)
"25 years old"
"I like "python""
>>> "%s is %d years old" % ("deason",25)
"deason is 25 years old"

%s 字符串(采用str()的顯示)

%r 字符串(采用repr()的顯示)

%c 單個字符

%b 二進制整數(shù)

%d 十進制整數(shù)

%e 指數(shù)(底數(shù)為e)

%f 浮點數(shù)

使用format格式化

{}作為占位符

>>> str = "I like {}".format("python");
>>> str
"I like python"
>>> str = "{0} is {1} years old".format("michael",25)
>>> str
"michael is 25 years old"
字典式格式化
>>> lang = "python"
>>> print "I love %(program)s" %{"program":lang}
I love python
>>> print "I love %(program)s" %{"program":"python"}
I love python

綜上,推薦使用:string.format()

Python列表

此前已經(jīng)知道了Python的三種對象類型:int、float和str。下面開始學習一種新的Python對象類型:list。list在Python中具有非常強大的功能。

定義

在Python中,用方括號表示一個list:[],方括號里面的元素類型,可以是int型數(shù)據(jù),也可以是str類型的數(shù)據(jù),甚至也可以是bool類型數(shù)據(jù)。而像Java語言,數(shù)組里面只能存在一種類型的數(shù)據(jù)。

>>> a=[]  #定義了一個空的列表,變量a相當于一個貼在其上的標簽
>>> type(a)  #用內(nèi)置函數(shù)type()查看變量a引用對象的類型,為list

>>> bool(a) #用內(nèi)置函數(shù)bool()查看a的布爾值,因為是空,所以為False
False
>>> print a
[]

下面看看list具體的使用

>>> a=["a",3,"hello",True]  #list中可以有多中數(shù)據(jù)類型
>>> a
["a", 3, "hello", True]
>>> type(a)

>>> bool(a)
True
>>> print a
["a", 3, "hello", True]
>>> a[3]
True
>>> type(a[3])
索引和切片 索引

和字符串中的索引類似,只不過list是以元素為單位,而不是以字符為單位進行索引。

>>> a=[2,3,True,"Hello,world"]
>>> a
[2, 3, True, "Hello,world"]
>>> a[0]
2
>>> a[1]
3
>>> a[2]
True
>>> a[3]
"Hello,world"
>>> type(a[0])

>>> type(a[2])

>>> type(a[3])


>>> a.index(2)
0
>>> a.index(3)
1
>>> a.index(True)
2
>>> a.index("Hello,world")
3
>>> 
切片
>>> lst = ["python","java","c++"]
>>> lst[-1]
"c++"
>>> lst[-3:-1]
["python", "java"]
>>> lst[-1:-3]
[]
>>> lst[0:3]
["python", "java", "c++"]
>>> 

序列的切片,一定要左邊的數(shù)字小于右邊的數(shù)字,lst[-1:-3]就沒有遵守這個規(guī)則,返回的是一個空。

反轉
>>> mList = [1,2,3,4,5,6]
>>> mList[::-1]
[6, 5, 4, 3, 2, 1]
>>> m
>>> mList
[1, 2, 3, 4, 5, 6]
>>> 

當然,也可以對字符串進行反轉:

>>> lang="python"
>>> lang[::-1]
"nohtyp"
>>> lang
"python"

可以看出,不管是str還是list,反轉之后原來的值沒有改變。這說明,這里的反轉不是把原來的值倒過來,而是新生成了一個值,生成的值跟原來的值相比是倒過來的。

Python還有一種方法使list反轉,且比較容易閱讀和理解,特別推薦:

mList = [1,2,3,4,5,5,6,8,7]
>>> list(reversed(mList))
[7, 8, 6, 5, 5, 4, 3, 2, 1]

>>> s="abcd"
>>> list(reversed(s))
["d", "c", "b", "a"]
"abcd"
對list的操作 len()
>>> lst=["python","java","c++"]
>>> len(lst)
3
+,連接連個序列
>>> lst=["python","java","c++"]
>>> lst
["python", "java", "c++"]
>>> alst =[1,2,3,4,5]
>>> lst + alst
["python", "java", "c++", 1, 2, 3, 4, 5]
*,重復元素
>>> lst * 3
["python", "java", "c++", "python", "java", "c++", "python", "java", "c++"]
in
>>> "python" in lst
True
max()和min()
>>> max(alst)
5
>>> min(alst)
1
>>> max(lst)
"python"
>>> min(lst)
"c++"
cmp()
>>> a = [2,3]
>>> b = [2,4]
>>> cmp(a,b)
-1
>>> cmp(b,a)
1
>>> c=[2]
>>> cmp(a,c)
1
>>> d=["2"]
>>> cmp(a,d)
-1
追加元素
>>> lst
["python", "java", "c++"]
>>> lst.append("html5") #將元素追加到list的尾部
>>> lst
["python", "java", "c++", "html5"]
>>> lst.append(100)
>>> lst
["python", "java", "c++", "html5", 100]

等價于:

>>> lst
["python", "java", "c++", "html5", 100]
>>> lst[len(lst):] = [3]
>>> lst
["python", "java", "c++", "html5", 100, 3]
>>> len(lst)
6
>>> lst[6:]=["javascript"]
>>> lst
["python", "java", "c++", "html5", 100, 3, "javascript"]
列表的函數(shù)

list是Python中的苦力,那么它都有哪些函數(shù)呢?

>>> dir(list)
["__add__", "__class__", "__contains__", "__delattr__", "__delitem__", "__delslice__", "__doc__", "__eq__", "__format__", "__ge__", "__getattribute__", "__getitem__", "__getslice__", "__gt__", "__hash__", "__iadd__", "__imul__", "__init__", "__iter__", "__le__", "__len__", "__lt__", "__mul__", "__ne__", "__new__", "__reduce__", "__reduce_ex__", "__repr__", "__reversed__", "__rmul__", "__setattr__", "__setitem__", "__setslice__", "__sizeof__", "__str__", "__subclasshook__", "append", "count", "extend", "index", "insert", "pop", "remove", "reverse", "sort"]

先不管以雙下劃線開始和結尾的函數(shù),就剩下以下幾個

"append", "count", "extend", "index", "insert", "pop", "remove", "reverse", "sort"
append和extend

list.append(x),是將某個元素x添加到已知的一個列表的尾部。

list.extend(L),則是將兩個列表合并,或者說將列表L追加到列表list中。

>>> a=[1,2,3]
>>> b=["lau",3,4,5]
>>> a.extend(b)
>>> a
[1, 2, 3, "lau", 3, 4, 5]
>>> b
["lau", 3, 4, 5]
>>> a=[1,2,3]
>>> b="abc"
>>> a.extend(b)
>>> a
[1, 2, 3, "a", "b", "c"]
>>> c = 5
>>> a.extend(c) 

Traceback (most recent call last):
  File "", line 1, in 
    a.extend(c)
TypeError: "int" object is not iterable

如果extend的參數(shù)對象是數(shù)值型則報錯。
所以,extend的參數(shù)對象是一個list,如果是str,則Python會先把它按照字符為單位轉化為list再添加到目標list中。官方文檔指出extend的元素對象必須是iterable(可迭代的)。

判斷一個對象是不是可迭代的?

>>> s="python"
>>> hasattr(s,"__iter__")
False
>>> a=[1,2,3]
>>> hasattr(a,"__iter__")
True

通過內(nèi)建函數(shù)hasattr()判斷一個對象是不是可迭代的,它的判斷本質就是看那個類型中是否有__iter__函數(shù)。

append和extend函數(shù)的相同點

>>> a=[1,2,3]
>>> b=[4,5,6]
>>> id(a)
49822856
>>> id(b)
50066536
>>> a.extend(b)
>>> a
[1, 2, 3, 4, 5, 6]
>>> id(a)
49822856
>>> a=[1,2,3]
>>> id(a)
50068376
>>> a.append(12)
>>> a
[1, 2, 3, 12]
>>> id(a)
50068376

由上面兩段代碼可知,append和extend函數(shù)的共同點:

都是原地址修改列表,不會創(chuàng)建一個新的列表

沒有返回值

append和extend函數(shù)的不同點

>>> lst=[1,2,3]
>>> lst.append(["python","java"])
>>> lst
[1, 2, 3, ["python", "java"]]
>>> len(lst)
4

>>> 
>>> lst2=[1,2,3]
>>> lst2.extend(["python","java"])
>>> lst2
[1, 2, 3, "python", "java"]

>>> len(lst2)
5

可知,append是整體的追加,extend是單個的追加

count

count的作用是計算某個元素在該list中出現(xiàn)的次數(shù)

>>> a=[1,2,1,1,1]
>>> a.count(1)
4
>>> a.append("a")
>>> a.append("a")
>>> a
[1, 2, 1, 1, 1, "a", "a"]
>>> a.count("a")
2
>>> a.count(4) #不存在,則返回為0
0
index

index計算元素在該列表首次出現(xiàn)的位置

>>> a=[1,2,3,4,4,5]
>>> a.index(4)
3
>>> a.index(6) #如果不存,就報錯

Traceback (most recent call last):
  File "", line 1, in 
    a.index(6)
ValueError: 6 is not in list
insert

list.insert(i,x),想列表中指定的位置插入元素x。

>>> a=[1,2,3,4,5]
>>> a.insert(0,0)
>>> a
[0, 1, 2, 3, 4, 5]
>>> a.insert(3,7)
>>> a
[0, 1, 2, 7, 3, 4, 5]
>>> a.insert(8,4)  #若超出列表長度,則將元素插入到列表末尾
>>> a
[0, 1, 2, 7, 3, 4, 5, 4]
pop和remove

刪除列表中元素的方法有兩個,分別是:

list.remove(x)

刪除列表中首次出現(xiàn)的元素x,如果不存在元素x,則報錯

>>> a
[0, 1, 2, 7, 3, 4, 5, 4]
>>> a.remove(4)
>>> a
[0, 1, 2, 7, 3, 5, 4]
>>> a.remove(6)

Traceback (most recent call last):
  File "", line 1, in 
    a.remove(6)
ValueError: list.remove(x): x not in list

list.pop([i])

刪除列表中位置i的元素并且返回該元素。如果沒有指定位置i,則默認刪除并返回列表的最后一個元素。

>>> a.pop(0) #刪除指定位置0
0
>>> a
[1, 2, 7, 3, 5, 4]
>>> a.pop() #刪除默認位置
4  
>>> a
[1, 2, 7, 3, 5]

>>> a.pop(5) #超過列表長度則會報錯

Traceback (most recent call last):
  File "", line 1, in 
    a.pop(5)
IndexError: pop index out of range
reverse

將列表的元素順序反過來,不會創(chuàng)建新的列表,因此沒有返回值

>>> a=[1,2,3,4,5,6,7]
>>> a.reverse()
>>> a
[7, 6, 5, 4, 3, 2, 1]
>>> a=["ss","aaa","dd"]

>>> a.reverse()
>>> a
["dd", "aaa", "ss"]
sort

sort是對列表進行排序,不會創(chuàng)建新的列表,因此沒有返回值

>>> a=[1,3,9,7,5] 
>>> a.sort() #默認從小到大的排序
>>> a
[1, 3, 5, 7, 9]
>>> a.sort(reverse = True) #從大到小的排序
>>> a
[9, 7, 5, 3, 1]
>>> lst=["python","java","c","basic","ruby"]
>>> lst.sort(key=len) #以字符串長度為關鍵詞進行排序
>>> lst
["c", "java", "ruby", "basic", "python"]
比較列表和字符串 相同點

都屬于序列,因此那些屬于序列的操作對兩者都適用

區(qū)別

最大區(qū)別是,列表自身可以改變,字符串自身不可以改變

字符串只能通過創(chuàng)建一個新的str來改變,新的str不是原來的字符串對象

多維列表

在字符串中,每個元素只能是字符

在列表中,每個元素可以是任何類型

>>> matrix=[[1,2,3],[4,5,6],[7,8,9]]
>>> type(matrix)

>>> matrix[0][1]
2
>>> matrix[0]
[1, 2, 3]
列表和字符串的相互轉化 str.split()
>>> line="hello I am good"
>>> line.split(" ")
["hello", "I", "am", "good"]
>>> a = line.split(" ")
>>> a
["hello", "I", "am", "good"]
>>> type(a)
"split".join(list)
>>> a
["hello", "I", "am", "good"]
>>> type(a)

>>> " ".join(a)
"hello I am good"
Python元組 定義

元組(tuple)是用圓括號括起來的,元素之間用逗號隔開。

>>> t = 123,"abc",["come","here"]
>>> t
(123, "abc", ["come", "here"])
>>> type(t)

元組也是一種序列,這一點與列表、字符串類似。有以下特點:

元組其中的元素不能更改,和字符串類似

元組中的元素可以是任何類型的數(shù)據(jù),和列表類似

索引和切片

元組的索引和切片的基本操作和字符串、列表是一樣的。

>>> t
(123, "abc", ["come", "here"])
>>> t[2]
["come", "here"]
>>> t[1:]
("abc", ["come", "here"])
>>> t[2][0]
"come"

特別注意:如果一個元組中只有一個元素,應該在該元素后面加上一個半角的英文逗號:

>>> a=(3)
>>> type(a)

>>> a=(3,) #加了逗號就是元組
>>> type(a)

列表和元組之間可以實現(xiàn)轉換,分別使用list()和tuple()

>>> t
(123, "abc", ["come", "here"])
>>> tlst = list(t)   # tuple--->list
>>> tlst
[123, "abc", ["come", "here"]]
>>> type(tlst)

>>> 
>>> t_tuple = tuple(tlst)  #list--->tuple
>>> t_tuple
(123, "abc", ["come", "here"])
>>> type(t_tuple)
用途

元組比列表操作速度快。如果定義了一個值的常量集,并且唯一要用它做的是不斷地遍歷它,請使用元組代替列表

如果對不需要修改的數(shù)據(jù)進行“寫保護”,可以使代碼更安全,這時使用元組而不是列表。如果必須要改變這些值,則需要執(zhí)行元組到列表的轉換。

元組可以在字典中被用作key,但是列表不行。因為字典的key必須是不可變的,元組本身是不可變的。

元組可以用在字符串格式化中。

文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://systransis.cn/yun/38210.html

相關文章

  • Python中的對象引用、可變性和垃圾回收

    摘要:一對象引用基礎知識變量是標注而不是容器。也就是說元組中不可變的是元素的標識,但元組的值會隨著引用的可變對象變化而變化。在中每個對象的引用都會有統(tǒng)計。弱引用不會妨礙對象被當做垃圾回收。 導語:本文章記錄了本人在學習Python基礎之面向對象篇的重點知識及個人心得,打算入門Python的朋友們可以來一起學習并交流。 本文重點: 1、明確變量保存的是引用這一本質;2、熟悉對象引用的基礎知識;...

    ytwman 評論0 收藏0
  • Python試水

    摘要:你好,特別注意定義編碼格式的這一行代碼必須放在第一行或者第二行,一般如果第一行是提示位置的代碼,那么定義編碼格式的這一行就必須放在第二行,否則依然會提示錯誤?;竟δ苁沁M行成員關系測試和刪除重復元素。 一、Hello,Python! 試水 test.py print 你好,Python! #python 2.x python (你好,Python!) #python 3.x 很不幸,第...

    zhjx922 評論0 收藏0
  • 萬物基礎——對象

    摘要:每個對象均有標識符類型值。通常我們認為當這些對象被垃圾回收機制回收時,它占用的外部資源即被釋放。造物主類型對象的類型幾乎影響了該對象的所有功能,在某種程度上,對象的標識符也受其類型的影響。 原文地址 對象 對象(Objects)是python中數(shù)據(jù)的抽象,python中所有的數(shù)據(jù)均可以用對象或者是對象之間的關系來表示。每個對象均有標識符(identity)、類型(type)、值(val...

    douzifly 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<