Python基本數據類型之字符串

str(字符串)前端

1.字符串是 Python 中最經常使用的數據類型。咱們能夠使用'',"", ''' ''' , """ """這四種方式來定義字符串;python

a = 'x'
b = "y"
c = '''xxx'''
d = """yyy"""
print(a,b,c,d)   #輸出:x y xxx yyy

2.字符串是不可變的,字符串一旦定義就不能改變;git

string = 'world'
string = 'hello world'

3.字符串的轉義;api

\:續行符;

\e:轉義;

\n:換行;

\ \:反斜槓符號;

\ ":單引號;

\ ":雙引號;

\000:空;

\v:縱向製表符;

\t:橫向製表符;

\r:回車;

\f:換頁;

\oyy:八進制數,yy表明的字符,例如:\o12表明換行;

xyy:十六進制數,yy表明的字符,例如:\x0a表明換行;

\other:其它的字符以普通格式輸出;

4.字符串能夠經過索引和循環迭代兩種方式來訪問;ide

# 索引訪問
str = 'hello'
print(str[1])  #輸出:e

# 循環迭代訪問
str1 = 'hello'
for item in str1:
    print(item)  #輸出:h e l l o

5.字符串的鏈接方式spa

  • 使用+號直接鏈接
string1 = 'hello'
string2 = '\t'
string3 = 'world'
print(string1 + string2 + string3)  #輸出:hello	world
  • 使用join方法鏈接
lst = ['1', '2', '3', '4', '5']
lst_new = ''.join(lst)
print(lst_new)    #輸出:12345

6.字符串的切割code

  • 使用 split(sep=None, maxsplit=num) -> list of strings , 從左向右切割,sep指定分隔符,maxsplit指定切割的次數, num指定切割多少次,若是不設置maxsplit參數,那就根據sep切割,不限定次數;
string1 = '1,2,3,4,5'
new_obj1 = string1.split(',')
new_obj2 = string1.split(',', maxsplit=1)

print(new_obj1)  #輸出:['1', '2', '3', '4', '5']
print(new_obj2)  #輸出:['1', '2,3,4,5']
  • 使用rsplit方法, rsplit(sep=None, maxsplit=num) -> list of strings,參數設置和split方法相似,不一樣之處在於, rsplit方法是從右向左切割的;
string1 = '1,2,3,4,5'
new_obj1 = string1.rsplit(',')
new_obj2 = string1.rsplit(',', maxsplit=1)
print(new_obj1)  #輸出:['1', '2', '3', '4', '5']
print(new_obj2)  #輸出:['1,2,3,4', '5']
  • 使用splitlines方法, splitlines([keepends]) -> list of strings, 換行符('\r', '\r\n', \n')切割, keepends指是否保留分隔符,True爲保留,False不保留;
string1 = 'I love xkd \nI love xkd'
new_obj1 = string1.splitlines()
new_obj2 = string1.splitlines(True)
print(new_obj1) #輸出:['I love xkd ', 'I love xkd']
print(new_obj2) #輸出:['I love xkd \n', 'I love xkd']
  • 使用partition方法, partition(sep) -> (head, sep, tail), 從左到右切割三段,中間那段爲分隔符。若是隻須要輸出其中一段,能夠把其它的段用_下劃線代替;
string1 = '1,2,3,4,5'
new_obj1, seq, new_obj2 = string1.partition(',')
print(new_obj1) #輸出:1
print(seq)      #輸出:,
print(new_obj2) #輸出:2,3,4,5

new_obj1, _, _ = string1.partition(',')
print(new_obj1)  #輸出:1

7.字符串對象方法orm

string = 'aBcd abcD'   #初始化一個字符串string
  • 所有轉爲大寫
print(string.upper())  #輸出:ABCD ABCD
  • 所有轉爲小寫
print(string.lower())  #輸出:abcd abcd
  • 大寫改小寫,小寫改大寫
print(string.swapcase())   #輸出:AbCD ABCd
  • 全部單詞首字母大寫
print(string.title())     #輸出:Abcd Abcd
  • 字符串首字母大寫
print(string.capitalize()) #輸出:Abcd abcd
  • center方法,center(width[, fillchar]) -> str, 將字符串居中,width指定寬度, fillchar指定填充的字符;
print(string.center(100, '*'))
輸出:**********aBcd abcD***********
  • ljust方法,ljust(width[, fillchar]), 將字符串居左,width指定寬度, fillchar指定填充的字符;
print(string.ljust(100, '*'))
輸出:aBcd abcD********************
  • rjust方法,rjust(width[, fillchar]), 將字符串居右,width指定寬度, fillchar指定填充的字符;
print(string.rjust(100, '*'))
輸出:********************aBcd abcD
  • zfill方法,zfill(width) -> str, 右對齊打印,左邊使用0填充;
print(string.zfill(100))
輸出:00000000000000000000aBcd abcD

8.字符串修改對象

  • replace方法,replace(old, new[, count]) -> str, 字符串替換,old指須要被替換的字符串,new爲替換字符串, count爲指定的次數;
string = 'age'
print(string.replace('a', 'z'))  #輸出:zge
  • strip方法,strip([chars]) -> str, 剔除兩端的字符,chars指定剔除的字符,chars不指定則爲剔除空白字符;
string = ' age '
print(string.strip())  #輸出:age

print(string.strip())  #輸出:age
  • lstrip: 剔除左邊的字符,rstrip: 剔除右邊的字符;
print(string.rstrip())  #輸出: age

print(string.lstrip())  #輸出:age

9.字符串查找索引

string = 'helloworld'
  • find方法,find(sub[, start[, end]]) -> int, 從左向右查找,sub指定要查找的字符串,[start,end] 爲開始和結束索引,返回索引;
print(string.find('e'))  #輸出:1
  • index方法,index(sub[, start[, end]]) -> int,返回索引;
print(string.index('w')) #輸出:5
  • count方法,count(sub[, start[, end]]) -> int, 返回字符出現的次數;
print(string.count('l')) #輸出:3

10.字符串判斷

string = 'hello'  #初始化一個字符串string
  • startswith方法,startswith(prefix[, start[, end]]) -> bool, 是否以prefix開頭;
print(string.startswith(''))  #輸出:True
  • endswith(suffix[, start[, end]]) -> bool, 是否以suffix結尾;
print(string.endswith('x'))  #輸出:False
  • isalnum() 是不是字母或數字;
print(string.isalnum())  #輸出:True
  • isalpha() 是不是字母;
print(string.isalpha())  #輸出:True
  • isdigit() 是不是數字;
print(string.isdecimal())  #輸出:False
  • isdecimal() 是不是十進制;
print(string.isdecimal())  #輸出:False
  • isidentifier() 是不是字母和下劃線開頭
print(string.isidentifier())  #輸出:True
  • islower() 是不是小寫;
print(string.islower())  #輸出:True
  • isupper() 是不是大寫;
print(string.isupper())  #輸出:False
  • isspace() 是不是全空白字符;
print(string.isspace())  #輸出:False

11.符串格式化

  • C語言風格
print("I am %04d" % (100,)) # 前端補0
print('I am %s' % 'hello')    # 字符串
print('%.3f' % (99.56789))  # 保留3位小數
print("I am %-5d" % (20,))  # 左對齊
print("I am %5d" % (20,))   # 右對齊
  • python format風格
S.format(*args, **kwargs) -> str, 其中args爲元組,kwargs爲字典,花括號爲佔位符

1: 佔位
print('我是{}, 我在{}'.format('魚兒', '海里'))

print('我是{0}, 我在{1}'.format('魚兒', '海里'))

print('我是{1}, 我在{0}'.format('海里','魚兒',))

print('我是{1}, 我在{0}'.format(*('海里','魚兒')))

print('我是{name}, 我在{addr}'.format(name='魚兒', addr='海里'))

print('我是{name}, 我在{addr}'.format(**{'name':'魚兒', 'addr':'海里'}))

2:對齊
# 指定100個位置,且左對齊
print('{0} + {1} = {2:<100}'.format(1,2,3))

# 指定100個位置,且右對齊
print('{0} + {1} = {2:>100}'.format(1,2,3))

# 指定100個位置,且左對齊,其餘地方補0
print('{0} + {1} = {2:0<100}'.format(1,2,3))

# 指定100個位置,且右對齊,其餘地方補0
print('{0} + {1} = {2:0>100}'.format(1,2,3))

# 指定100個位置,居中對齊
print('{0} + {1} = {2:^100}'.format(1,2,3))

# 指定100個位置,居中對齊, 其餘地方補0
print('{0} + {1} = {2:0^100}'.format(1,2,'不知道'))

# 進制
print("int: {0:d} bin: {0:b} hex: {0:x} oct: {0:o} ".format(100))
print("int: {0:d} bin: {0:#b} hex: {0:#x} oct: {0:#o} ".format(100))

本文參考自俠課島(9xkd.com)Python同窗計劃

相關文章
相關標籤/搜索