电竞比分网-中国电竞赛事及体育赛事平台

分享

python中l(wèi)ist與string的轉換

 O聽_海_軒O 2020-07-16

1.list轉string

命令:''.join(list)

其中,引號中是字符之間的分割符,如“,”,“;”,“\t”等等

如:

list = [1, 2, 3, 4, 5]

''.join(list) 結果即為:12345

','.join(list) 結果即為:1,2,3,4,5

  1. str=[] #有的題目要輸出字符串,但是有時候list更好操作,于是可以最后list轉string提交
  2. for i in range(0,a):
  3. str.append('M')
  4. str1=''.join(str)

2.string轉list

命令:list(str)

  1. import string
  2. str = 'abcde'
  3. print(str)
  4. #輸出:abcde
  5. list1 = list(str)
  6. print(list1)
  7. #輸出:['a', 'b', 'c', 'd', 'e']

這里在jupyter報錯,在pycharm上沒有出錯,網(wǎng)上說是命名成list問題,但改過也如此。母雞了!

值得注意的是,比如“abs"這種字符串,要想分隔開,只能用list("abs"),才能得到['a','b','c']

  1. a='123 4'
  2. b = list(a)
  3. print(b)
  4. #['1', '2', '3', ' ', '4']

 

或者使用string的函數(shù)

str.split()

這個內(nèi)置函數(shù)實現(xiàn)的是將str轉化為list。其中str=""是分隔符。

  1. >>> line = "Hello.I am qiwsir.Welcome you."
  2. >>> line.split(".") #以英文的句點為分隔符,得到list
  3. ['Hello', 'I am qiwsir', 'Welcome you', '']
  4. >>> line.split(".",1) #這個1,就是表達了上文中的:If maxsplit is given, at most maxsplit splits are done.
  5. ['Hello', 'I am qiwsir.Welcome you.']
  6. >>> name = "Albert Ainstain" #也有可能用空格來做為分隔符
  7. >>> name.split(" ")
  8. ['Albert', 'Ainstain']

值得注意的是:
 

  1. a = '123 4'
  2. b = list(a)
  3. print(b)
  4. c = a.split()
  5. print(c)
  6. #['123', '4']
  7. d = a.split(' ')
  8. print(d)
  9. #['123', '', '4']
  10. #split()默認的是空白的區(qū)域作為分割,可能是幾個空格作為分割,而split(' ')是空格,在連續(xù)的n個空格中,會有n-1個空格作為分割后的元素

python里字符串數(shù)組轉化為整型, 用list(map(type,arr))函數(shù)

  1. py2:
  2. >>> arr = ['22','44','66','88']
  3. >>> arr = map(int,arr)
  4. >>> print(arr)
  5. [22, 44, 66, 88]
  6. py3:
  7. >>> arr = ['22','44','66','88']
  8. >>> arr = list(map(int,arr))
  9. >>> print(arr)
  10. [22, 44, 66, 88]

3.為什么要轉來轉去?

肯定是各有好處了!

list是列表,其特點是不定長,所以可以list.append隨時增加,也可以insert插入

  1. list1=['a','b','c','d','e']
  2. list1.insert(2,'c')
  3. print(list1)
  4. #輸出:['a', 'b', 'c', 'c', 'd', 'e']

下標索引【詳見https://www.runoob.com/python/python-lists.html】:

  1. #!/usr/bin/python
  2. list1 = ['physics', 'chemistry', 1997, 2000]
  3. list2 = [1, 2, 3, 4, 5, 6, 7 ]
  4. print "list1[0]: ", list1[0]
  5. print "list2[1:5]: ", list2[1:5]
  6. #輸出:
  7. list1[0]: physics
  8. list2[1:5]: [2, 3, 4, 5]
  9. list1 = ['physics', 'chemistry', 1997, 2000]
  10. print list1
  11. del list1[2] #刪除,用del

這里附上list類常用函數(shù)與方法:

作者:張xxxxxx 
來源:CSDN 
原文:https://blog.csdn.net/weixin_38284096/article/details/80409856 

Python列表操作的函數(shù)和方法
列表操作包含以下函數(shù):
1、cmp(list1, list2):比較兩個列表的元素 
2、len(list):列表元素個數(shù) 
3、max(list):返回列表元素最大值 
4、min(list):返回列表元素最小值 
5、list(seq):將元組轉換為列表 
列表操作包含以下方法:
1、list.append(obj):在列表末尾添加新的對象
2、list.count(obj):統(tǒng)計某個元素在列表中出現(xiàn)的次數(shù)
3、list.extend(seq):在列表末尾一次性追加另一個序列中的多個值(用新列表擴展原來的列表)
4、list.index(obj):從列表中找出某個值第一個匹配項的索引位置
5、list.insert(index, obj):將對象插入列表
6、list.pop(obj=list[-1]):移除列表中的一個元素(默認最后一個元素),并且返回該元素的值
7、list.remove(obj):移除列表中某個值的第一個匹配項
8、list.reverse():反向列表中元素
9、list.sort([func]):對原列表進行排序
--------------------- 
list容易實現(xiàn)隊列queue的操作【出隊,入隊】,還有棧stack的操作,出棧入棧;

https://blog.csdn.net/w571523631/article/details/55099385

  1. #強哥寫的一個
  2. #self表示實例本身
  3. class Queue(object):
  4. def __init__(self):
  5. self._items = []
  6. def size(self):
  7. return len(self._items)
  8. def isEmpty(self):
  9. return self.size() == 0
  10. def pop(self):
  11. if self.isEmpty():
  12. raise Exception("The queue is empty.")
  13. else:
  14. temp = self._items[0]
  15. del self._items[0]
  16. return temp
  17. def push(self, newItem):
  18. self._items.append(newItem)
  19. def __getitem__(self, item):
  20. return self._items[item]
  21. def getQueue(self):
  22. return self._items
  23. class Stack(object):
  24. def __init__(self):
  25. self._items = []
  26. def size(self):
  27. return len(self._items)
  28. def isEmpty(self):
  29. return self.size() == 0
  30. def pop(self):
  31. if self.isEmpty():
  32. raise Exception('The stack is empty.')
  33. else:
  34. temp = self._items[0]
  35. del self._items[0]
  36. return temp
  37. def push(self, newItem):
  38. self._items.insert(0, newItem)
  39. def __getitem__(self, item):
  40. return self._items[item]
  41. def refresh(self, newItems):
  42. self._items = newItems

python2里加了object就可以有更多的繼承屬

來自:https://blog.csdn.net/w571523631/article/details/55099385

  1. # -.- coding:utf-8 -.-
  2. # __author__ = 'zhengtong'
  3. class Person:
  4. """
  5. 不帶object
  6. """
  7. name = "zhengtong"
  8. class Animal(object):
  9. """
  10. 帶有object
  11. """
  12. name = "chonghong"
  13. if __name__ == "__main__":
  14. x = Person()
  15. print "Person", dir(x)
  16. y = Animal()
  17. print "Animal", dir(y)
  18. #運行結果:
  19. Person ['__doc__', '__module__', 'name']
  20. Animal ['__class__', '__delattr__', '__dict__', '__doc__', '__format__', '__getattribute__',
  21. '__hash__', '__init__', '__module__', '__new__', '__reduce__', '__reduce_ex__', '__repr__',
  22. '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', 'name']
  23. Person類很明顯能夠看出區(qū)別,不繼承object對象,只擁有了doc , module 和 自己定義的name變量, 也就是說這個類的命名空間只有三個對象可以操作.
  24. Animal類繼承了object對象,擁有了好多可操作對象,這些都是類中的高級特性。
  25. 對于不太了解python類的同學來說,這些高級特性基本上沒用處,但是對于那些要著手寫框架或者寫大型項目的高手來說,這些特性就比較有用了,比如說tornado里面的異常捕獲時就有用到class來定位類的名稱,還有高度靈活傳參數(shù)的時候用到dict來完成.
  26. 最后需要說清楚的一點, 本文是基于python 2.7.10版本,實際上在python 3 中已經(jīng)默認就幫你加載了object了(即便你沒有寫上object)。

那么string呢?

資料來自:菜鳥編程 https://www.runoob.com/python/python-strings.html

Python字符串運算符

下表實例變量 a 值為字符串 "Hello",b 變量值為 "Python":

操作符 描述 實例
+ 字符串連接

>>>a + b 'HelloPython'

* 重復輸出字符串

>>>a * 2 'HelloHello'

[] 通過索引獲取字符串中字符

>>>a[1] 'e'

[ : ] 截取字符串中的一部分

>>>a[1:4] 'ell'

in 成員運算符 - 如果字符串中包含給定的字符返回 True

>>>"H" in a True

not in 成員運算符 - 如果字符串中不包含給定的字符返回 True

>>>"M" not in a True

Python 字符串格式化

Python 支持格式化字符串的輸出 。盡管這樣可能會用到非常復雜的表達式,但最基本的用法是將一個值插入到一個有字符串格式符 %s 的字符串中。

在 Python 中,字符串格式化使用與 C 中 sprintf 函數(shù)一樣的語法。

python字符串格式化符號:

    符   號 描述
      %c  格式化字符及其ASCII碼
      %s  格式化字符串
      %d  格式化整數(shù)
      %u  格式化無符號整型
      %o  格式化無符號八進制數(shù)
      %x  格式化無符號十六進制數(shù)
      %X  格式化無符號十六進制數(shù)(大寫)
      %f  格式化浮點數(shù)字,可指定小數(shù)點后的精度
      %e  用科學計數(shù)法格式化浮點數(shù)
      %E  作用同%e,用科學計數(shù)法格式化浮點數(shù)
      %g  %f和%e的簡寫
      %G  %f 和 %E 的簡寫
      %p  用十六進制數(shù)格式化變量的地址

 字符串可以很方便的下標索引,連接,復制

 

Python轉義字符

在需要在字符中使用特殊字符時,python用反斜杠(\)轉義字符。如下表:

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

Python字符串運算符

下表實例變量 a 值為字符串 "Hello",b 變量值為 "Python":

操作符 描述 實例
+ 字符串連接

>>>a + b 'HelloPython'

* 重復輸出字符串

>>>a * 2 'HelloHello'

[] 通過索引獲取字符串中字符

>>>a[1] 'e'

[ : ] 截取字符串中的一部分

>>>a[1:4] 'ell'

in 成員運算符 - 如果字符串中包含給定的字符返回 True

>>>"H" in a True

not in 成員運算符 - 如果字符串中不包含給定的字符返回 True

>>>"M" not in a True

r/R 原始字符串 - 原始字符串:所有的字符串都是直接按照字面的意思來使用,沒有轉義特殊或不能打印的字符。 原始字符串除在字符串的第一個引號前加上字母"r"(可以大小寫)以外,與普通字符串有著幾乎完全相同的語法。

>>>print r'\n' \n >>> print R'\n' \n

% 格式字符串 請看下一章節(jié)

 

Python 字符串格式化

Python 支持格式化字符串的輸出 。盡管這樣可能會用到非常復雜的表達式,但最基本的用法是將一個值插入到一個有字符串格式符 %s 的字符串中。

在 Python 中,字符串格式化使用與 C 中 sprintf 函數(shù)一樣的語法。

python字符串格式化符號:

 

    符   號 描述
      %c  格式化字符及其ASCII碼
      %s  格式化字符串
      %d  格式化整數(shù)
      %u  格式化無符號整型
      %o  格式化無符號八進制數(shù)
      %x  格式化無符號十六進制數(shù)
      %X  格式化無符號十六進制數(shù)(大寫)
      %f  格式化浮點數(shù)字,可指定小數(shù)點后的精度
      %e  用科學計數(shù)法格式化浮點數(shù)
      %E  作用同%e,用科學計數(shù)法格式化浮點數(shù)
      %g  %f和%e的簡寫
      %G  %f 和 %E 的簡寫
      %p  用十六進制數(shù)格式化變量的地址

格式化操作符輔助指令:

符號 功能
* 定義寬度或者小數(shù)點精度
- 用做左對齊
+ 在正數(shù)前面顯示加號( + )
<sp> 在正數(shù)前面顯示空格
# 在八進制數(shù)前面顯示零('0'),在十六進制前面顯示'0x'或者'0X'(取決于用的是'x'還是'X')
0 顯示的數(shù)字前面填充'0'而不是默認的空格
% '%%'輸出一個單一的'%'
(var) 映射變量(字典參數(shù))
m.n. m 是顯示的最小總寬度,n 是小數(shù)點后的位數(shù)(如果可用的話)

 


python的字符串內(nèi)建函數(shù)

字符串方法是從python1.6到2.0慢慢加進來的——它們也被加到了Jython中。

這些方法實現(xiàn)了string模塊的大部分方法,如下表所示列出了目前字符串內(nèi)建支持的方法,所有的方法都包含了對Unicode的支持,有一些甚至是專門用于Unicode的。

方法 描述

string.capitalize()

把字符串的第一個字符大寫

string.center(width)

返回一個原字符串居中,并使用空格填充至長度 width 的新字符串

string.count(str, beg=0, end=len(string))

返回 str 在 string 里面出現(xiàn)的次數(shù),如果 beg 或者 end 指定則返回指定范圍內(nèi) str 出現(xiàn)的次數(shù)

string.decode(encoding='UTF-8', errors='strict')

以 encoding 指定的編碼格式解碼 string,如果出錯默認報一個 ValueError 的 異 常 , 除非 errors 指 定 的 是 'ignore' 或 者'replace'

string.encode(encoding='UTF-8', errors='strict')

以 encoding 指定的編碼格式編碼 string,如果出錯默認報一個ValueError 的異常,除非 errors 指定的是'ignore'或者'replace'

string.endswith(obj, beg=0, end=len(string))

檢查字符串是否以 obj 結束,如果beg 或者 end 指定則檢查指定的范圍內(nèi)是否以 obj 結束,如果是,返回 True,否則返回 False.

string.expandtabs(tabsize=8)

把字符串 string 中的 tab 符號轉為空格,tab 符號默認的空格數(shù)是 8。

string.find(str, beg=0, end=len(string))

檢測 str 是否包含在 string 中,如果 beg 和 end 指定范圍,則檢查是否包含在指定范圍內(nèi),如果是返回開始的索引值,否則返回-1

string.format()

格式化字符串

string.index(str, beg=0, end=len(string))

跟find()方法一樣,只不過如果str不在 string中會報一個異常.

string.isalnum()

如果 string 至少有一個字符并且所有字符都是字母或數(shù)字則返

回 True,否則返回 False

string.isalpha()

如果 string 至少有一個字符并且所有字符都是字母則返回 True,

否則返回 False

string.isdecimal()

如果 string 只包含十進制數(shù)字則返回 True 否則返回 False.

string.isdigit()

如果 string 只包含數(shù)字則返回 True 否則返回 False.

string.islower()

如果 string 中包含至少一個區(qū)分大小寫的字符,并且所有這些(區(qū)分大小寫的)字符都是小寫,則返回 True,否則返回 False

string.isnumeric()

如果 string 中只包含數(shù)字字符,則返回 True,否則返回 False

string.isspace()

如果 string 中只包含空格,則返回 True,否則返回 False.

string.istitle()

如果 string 是標題化的(見 title())則返回 True,否則返回 False

string.isupper()

如果 string 中包含至少一個區(qū)分大小寫的字符,并且所有這些(區(qū)分大小寫的)字符都是大寫,則返回 True,否則返回 False

string.join(seq)

以 string 作為分隔符,將 seq 中所有的元素(的字符串表示)合并為一個新的字符串

string.ljust(width)

返回一個原字符串左對齊,并使用空格填充至長度 width 的新字符串

string.lower()

轉換 string 中所有大寫字符為小寫.

string.lstrip()

截掉 string 左邊的空格

string.maketrans(intab, outtab])

maketrans() 方法用于創(chuàng)建字符映射的轉換表,對于接受兩個參數(shù)的最簡單的調用方式,第一個參數(shù)是字符串,表示需要轉換的字符,第二個參數(shù)也是字符串表示轉換的目標。

max(str)

返回字符串 str 中最大的字母。

min(str)

返回字符串 str 中最小的字母。

string.partition(str)

有點像 find()和 split()的結合體,從 str 出現(xiàn)的第一個位置起,把 字 符 串 string 分 成 一 個 3 元 素 的 元 組 (string_pre_str,str,string_post_str),如果 string 中不包含str 則 string_pre_str == string.

string.replace(str1, str2,  num=string.count(str1))

把 string 中的 str1 替換成 str2,如果 num 指定,則替換不超過 num 次.

string.rfind(str, beg=0,end=len(string) )

類似于 find()函數(shù),不過是從右邊開始查找.

string.rindex( str, beg=0,end=len(string))

類似于 index(),不過是從右邊開始.

string.rjust(width)

返回一個原字符串右對齊,并使用空格填充至長度 width 的新字符串

string.rpartition(str)

類似于 partition()函數(shù),不過是從右邊開始查找

string.rstrip()

刪除 string 字符串末尾的空格.

string.split(str="", num=string.count(str))

以 str 為分隔符切片 string,如果 num 有指定值,則僅分隔 num+ 個子字符串

string.splitlines([keepends])

按照行('\r', '\r\n', \n')分隔,返回一個包含各行作為元素的列表,如果參數(shù) keepends 為 False,不包含換行符,如果為 True,則保留換行符。

string.startswith(obj, beg=0,end=len(string))

檢查字符串是否是以 obj 開頭,是則返回 True,否則返回 False。如果beg 和 end 指定值,則在指定范圍內(nèi)檢查.

string.strip([obj])

在 string 上執(zhí)行 lstrip()和 rstrip()

string.swapcase()

翻轉 string 中的大小寫

string.title()

返回"標題化"的 string,就是說所有單詞都是以大寫開始,其余字母均為小寫(見 istitle())

string.translate(str, del="")

根據(jù) str 給出的表(包含 256 個字符)轉換 string 的字符,

要過濾掉的字符放到 del 參數(shù)中

string.upper()

轉換 string 中的小寫字母為大寫

string.zfill(width)

返回長度為 width 的字符串,原字符串 string 右對齊,前面填充0

 返回長度,都可以用len函數(shù)。len(list)或者len(string)。這些性質類似,是因為他們都是序列型數(shù)據(jù)。所謂序列類型的數(shù)據(jù),就是說它的每一個元素都可以通過指定一個編號,行話叫做“偏移量”的方式得到,而要想一次得到多個元素,可以使用切片。偏移量從0開始,總元素數(shù)減1結束。

https://www.jb51.net/article/55418.htm這篇文章講了另一些區(qū)別:

1.string的位置上只能放字符,而list是可以放多種類型信息,甚至多維數(shù)據(jù)

2.string不能在原來位置上,直接改動,而list可以。

多維list

這個也應該算是兩者的區(qū)別了,雖然有點牽強。在str中,里面的每個元素只能是字符,在list中,元素可以是任何類型的數(shù)據(jù)。前面見的多是數(shù)字或者字符,其實還可以這樣:

1

2

3

4

5

6

7

8

9

10

11

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

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

>>> matrix[0][1]

2

>>> mult = [[1,2,3],['a','b','c'],'d','e']

>>> mult

[[1, 2, 3], ['a', 'b', 'c'], 'd', 'e']

>>> mult[1][1]

'b'

>>> mult[2]

'd'

以上顯示了多維list以及訪問方式。在多維的情況下,里面的list也跟一個前面元素一樣對待。

 

4.既然各有好處,可否合起來呢?string[]與list<string>

參考這兩篇文章

https://blog.csdn.net/zxf1242652895/article/details/83345573

https://blog.csdn.net/qq_33774822/article/details/83188727

 

 

1.參考文章:https://www.cnblogs.com/huwang-sun/p/6972990.html

    本站是提供個人知識管理的網(wǎng)絡存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權內(nèi)容,請點擊一鍵舉報。
    轉藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多