摘要:字符串在中,萬物皆對象,顯然字符串是對象類型,用表示。其二是聲明為原始字符串如,由開頭引起的字符串就是聲明了后面引號里的東西是原始字符串,在里面放任何字符都表示該字符的原始含義,不需要再用轉義符了。
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` #反引號將整數a轉化為字符串 free1989 >>>
用“+”拼接起來的字符串的兩個對象必須是同一類型的。如果是數字則是求和,如果是字符串則得到一個新的字符串。
還有其他兩種方法可以將整數轉化為字符串:
str():將整數對象轉換為字符串對象
>>> print b + str(a) free1989
repr():相當于反引號``
>>> print b + repr(a) free1989
int():將字符串對象轉換為整數對象
>>> a = "250" >>> b = int(a) >>> b 250 >>> type(b)轉義字符>>>
在字符串中,總會有一些特殊的符號,就需要用轉義符。所謂轉義,就是不采用符號本來的含義,而采用另外一含義。下面表格中列出常用的轉義符:
轉義字符 | 描述 |
---|---|
(在行尾時) 續行符 | |
反斜杠符號 | |
" | 單引號 |
" | 雙引號 |
a | 響鈴 |
b | 退格(Backspace) |
e | 轉義 |
000 | 空 |
n | 換行 |
v | 縱向制表符 |
t | 橫向制表符 |
r | 回車 |
f | 換頁 |
oyy | 八進制數,yy代表的字符,例如:o12代表換行 |
xyy | 十六進制數,yy代表的字符,例如:x0a代表換行 |
other | 其它的字符以普通格式輸出 |
用轉義符能夠讓字符串中的某些符號表示原來的含義,而不是被解析成某種具有特別能力的符號。下面看看這個代碼:
>>> dos = "c: ews" >>> dos "c: ews" >>> print dos #當用print打印時就出現問題了 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下面實現接收和打印用戶通過鍵盤輸入的內容:
不過在寫這個功能前,要了解函數:
Python 2:raw_input()
Python 3: input()
這是Python的內建函數(built-in function)。關于內建函數,可以分別通過下面的鏈接查看:
Python 2的內建函數
Python 3的內建函數
關于Python的內建函數,下面列出來,供參考:
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()
怎么才能知道哪個函數怎么用,并且用來干什么的呢?
help(abs)命令
Python的官網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 #輸入數字 >>> age "25" >>> type(age) #返回仍是str類型
>>> print "Hello, world" Hello, world >>> a = "python" >>> print a python >>> b = "good" >>> print a,b python good >>>
特別提醒的是,print的返回值默認是以n結尾的,所以每個輸出語句之后自動換行。
索引和切片 索引在Python中,把像字符串這樣的對象類型統稱為序列,顧名思義,序列就是有序排列。在這個序列中,每個人都有編號,編號和每個字符一一對應,在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] #如果第二個數字的長度大于字符串的長度,得到的返回結果就自動到最大長度終止,但是這種獲得切片的方法是值得提倡的。特別是如果在循環中,這樣做很可能會遇到麻煩。 "study python" >>> lang[0:14] "study python
如果在切片的時候,冒號左右都不寫數字,就是前面所操作的c = lang[:],其結果是變量的值c與源字符串lang一樣,即復制了一份,那是不是真的復制呢?下面的方式檢驗一下:
>>> id(c) 44841944 >>> id(lang) 44841944
從上面可以看出,兩個內存地址一樣,說明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用來判斷某個字符串是不是在另外一個字符串內,或者判斷某個字符串內是否包含某個字符串,包含則返回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()
將兩個字符串進行比較,首先將字符串中的符號轉化為對應的數字,然后再比較
如果返回的數值小于0,說明前者小于后者
等于0,表示兩者相等
大于0,表示前者大于后者
>>> cmp("aaa","abc") # -1 >>> cmp("abc","aaa"); 1 >>> cmp("abc","abc"); 0
>>> ord("a") #返回字符的ASCII值 97 >>> chr(97) #返回ASCII值所對應的字符 "a""*"
以指定的次數重復打印字符串
>>> 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()作用是將字符串根據某個分隔符進行分割。
>>> 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() #將小寫字母完全變為大寫字母 "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表示整數 "25 years old" "I like "python"" >>> "%s is %d years old" % ("deason",25) "deason is 25 years old"
%s 字符串(采用str()的顯示)
%r 字符串(采用repr()的顯示)
%c 單個字符
%b 二進制整數
%d 十進制整數
%e 指數(底數為e)
%f 浮點數
使用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列表此前已經知道了Python的三種對象類型:int、float和str。下面開始學習一種新的Python對象類型:list。list在Python中具有非常強大的功能。
定義在Python中,用方括號表示一個list:[],方括號里面的元素類型,可以是int型數據,也可以是str類型的數據,甚至也可以是bool類型數據。而像Java語言,數組里面只能存在一種類型的數據。
>>> a=[] #定義了一個空的列表,變量a相當于一個貼在其上的標簽 >>> type(a) #用內置函數type()查看變量a引用對象的類型,為list>>> bool(a) #用內置函數bool()查看a的布爾值,因為是空,所以為False False >>> print a []
下面看看list具體的使用
>>> a=["a",3,"hello",True] #list中可以有多中數據類型 >>> 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++"] >>>
序列的切片,一定要左邊的數字小于右邊的數字,lst[-1:-3]就沒有遵守這個規則,返回的是一個空。
反轉>>> 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 Truemax()和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"]列表的函數
list是Python中的苦力,那么它都有哪些函數呢?
>>> 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"]
先不管以雙下劃線開始和結尾的函數,就剩下以下幾個
"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的參數對象是數值型則報錯。
所以,extend的參數對象是一個list,如果是str,則Python會先把它按照字符為單位轉化為list再添加到目標list中。官方文檔指出extend的元素對象必須是iterable(可迭代的)。
判斷一個對象是不是可迭代的?
>>> s="python" >>> hasattr(s,"__iter__") False >>> a=[1,2,3] >>> hasattr(a,"__iter__") True
通過內建函數hasattr()判斷一個對象是不是可迭代的,它的判斷本質就是看那個類型中是否有__iter__函數。
append和extend函數的相同點
>>> 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函數的共同點:
都是原地址修改列表,不會創建一個新的列表
沒有返回值
append和extend函數的不同點
>>> 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是單個的追加
countcount的作用是計算某個元素在該list中出現的次數
>>> 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 0index
index計算元素在該列表首次出現的位置
>>> a=[1,2,3,4,4,5] >>> a.index(4) 3 >>> a.index(6) #如果不存,就報錯 Traceback (most recent call last): File "insert", line 1, in a.index(6) ValueError: 6 is not in list
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)
刪除列表中首次出現的元素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 "reverse", line 1, in a.pop(5) IndexError: pop index out of range
將列表的元素順序反過來,不會創建新的列表,因此沒有返回值
>>> 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是對列表進行排序,不會創建新的列表,因此沒有返回值
>>> 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"]比較列表和字符串 相同點
都屬于序列,因此那些屬于序列的操作對兩者都適用
區別最大區別是,列表自身可以改變,字符串自身不可以改變
字符串只能通過創建一個新的str來改變,新的str不是原來的字符串對象
多維列表在字符串中,每個元素只能是字符
在列表中,每個元素可以是任何類型
>>> matrix=[[1,2,3],[4,5,6],[7,8,9]] >>> type(matrix)列表和字符串的相互轉化 str.split()>>> matrix[0][1] 2 >>> matrix[0] [1, 2, 3]
>>> 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)Python元組 定義>>> " ".join(a) "hello I am good"
元組(tuple)是用圓括號括起來的,元素之間用逗號隔開。
>>> t = 123,"abc",["come","here"] >>> t (123, "abc", ["come", "here"]) >>> type(t)
元組也是一種序列,這一點與列表、字符串類似。有以下特點:
元組其中的元素不能更改,和字符串類似
元組中的元素可以是任何類型的數據,和列表類似
索引和切片元組的索引和切片的基本操作和字符串、列表是一樣的。
>>> 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)
列表和元組之間可以實現轉換,分別使用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)
元組比列表操作速度快。如果定義了一個值的常量集,并且唯一要用它做的是不斷地遍歷它,請使用元組代替列表
如果對不需要修改的數據進行“寫保護”,可以使代碼更安全,這時使用元組而不是列表。如果必須要改變這些值,則需要執行元組到列表的轉換。
元組可以在字典中被用作key,但是列表不行。因為字典的key必須是不可變的,元組本身是不可變的。
元組可以用在字符串格式化中。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/38210.html
摘要:一對象引用基礎知識變量是標注而不是容器。也就是說元組中不可變的是元素的標識,但元組的值會隨著引用的可變對象變化而變化。在中每個對象的引用都會有統計。弱引用不會妨礙對象被當做垃圾回收。 導語:本文章記錄了本人在學習Python基礎之面向對象篇的重點知識及個人心得,打算入門Python的朋友們可以來一起學習并交流。 本文重點: 1、明確變量保存的是引用這一本質;2、熟悉對象引用的基礎知識;...
閱讀 3129·2021-11-15 18:14
閱讀 1781·2021-09-22 10:51
閱讀 3294·2021-09-09 09:34
閱讀 3511·2021-09-06 15:02
閱讀 1027·2021-09-01 11:40
閱讀 3194·2019-08-30 13:58
閱讀 2532·2019-08-30 11:04
閱讀 1088·2019-08-28 18:31