各個(gè)數(shù)據(jù)類型的內(nèi)置方法(字符串和列表)
(資料圖片僅供參考)
各個(gè)數(shù)據(jù)類型的內(nèi)置方法整形和浮點(diǎn)型的內(nèi)置方法# 1、定義:# 1.1 整型int的定義age=10 # 本質(zhì)age = int(10)# 1.2 浮點(diǎn)型float的定義salary=3000.3 # 本質(zhì)salary=float(3000.3)# 注意:名字+括號(hào)的意思就是調(diào)用某個(gè)功能,比如# print(...)調(diào)用打印功能# int(...)調(diào)用創(chuàng)建整型數(shù)據(jù)的功能# float(...)調(diào)用創(chuàng)建浮點(diǎn)型數(shù)據(jù)的功能
# 1、數(shù)據(jù)類型轉(zhuǎn)換# 1.1 int可以將由純整數(shù)構(gòu)成的字符串直接轉(zhuǎn)換成整型,若包含其他任意非整數(shù)符號(hào),則會(huì)報(bào)錯(cuò)>>> s = "123">>> res = int(s)>>> res,type(res)(123, )>>> int("12.3") # 錯(cuò)誤演示:字符串內(nèi)包含了非整數(shù)符號(hào).Traceback (most recent call last): File "", line 1, in ValueError: invalid literal for int() with base 10: "12.3" # 1.2 進(jìn)制轉(zhuǎn)換# 十進(jìn)制轉(zhuǎn)其他進(jìn)制>>> bin(3)"0b11">>> oct(9)"0o11">>> hex(17)"0x11"# 其他進(jìn)制轉(zhuǎn)十進(jìn)制>>> int("0b11",2)3>>> int("0o11",8)9>>> int("0x11",16)17# 1.3 float同樣可以用來做數(shù)據(jù)類型的轉(zhuǎn)換>>> s = "12.3">>> res=float(s)>>> res,type(res)(12.3, )
數(shù)字類型主要就是用來做數(shù)學(xué)運(yùn)算與比較運(yùn)算,因此數(shù)字類型除了與運(yùn)算符結(jié)合使用之外,并無需要掌握的內(nèi)置方法
字符串# 定義:在單引號(hào)\雙引號(hào)\三引號(hào)內(nèi)包含一串字符name1 = "jason" # 本質(zhì):name = str("任意形式內(nèi)容")name2 = "lili" # 本質(zhì):name = str("任意形式內(nèi)容")name3 = """ricky""" # 本質(zhì):name = str("""任意形式內(nèi)容""")
數(shù)據(jù)類型轉(zhuǎn)換:str()可以將任何數(shù)據(jù)類型轉(zhuǎn)換為字符串類型,例如:python(str([1,2,3]))#list->str<>python(type(str({"name":"jaswe","age":18})))# dict->strprint(type(str({1,2,3,4})))print(type(str((1,2,3))))
基礎(chǔ)>>> str1 = "hello python!"# 1.按索引取值(正向取,反向取):# 1.1 正向取(從左往右)>>> str1[6]p# 1.2 反向取(負(fù)號(hào)表示從右往左)>>> str1[-4]h# 1.3 對(duì)于str來說,只能按照索引取值,不能改>>> str1[0]="H" # 報(bào)錯(cuò)TypeError# 2.切片(顧頭不顧尾,步長)# 2.1 顧頭不顧尾:取出索引為0到8的所有字符>>> str1[0:9] hello pyt# 2.2 步長:0:9:2,第三個(gè)參數(shù)2代表步長,會(huì)從0開始,每次累加一個(gè)2即可,所以會(huì)取出索引0、2、4、6、8的字符>>> str1[0:9:2] hlopt # 2.3 反向切片>>> str1[::-1] # -1表示從右往左依次取值!nohtyp olleh# 3.長度len# 3.1 獲取字符串的長度,即字符的個(gè)數(shù),但凡存在于引號(hào)內(nèi)的都算作字符)>>> len(str1) # 空格也算字符13# 4.成員運(yùn)算 in 和 not in# 4.1 int:判斷hello 是否在 str1里面>>> "hello" in str1 True# 4.2 not in:判斷tony 是否不在 str1里面>>> "tony" not in str1 True# 5.strip移除字符串首尾指定的字符(默認(rèn)移除空格)# 5.1 括號(hào)內(nèi)不指定字符,默認(rèn)移除首尾空白字符(空格、\n、\t)>>> str1 = " life is short! ">>> str1.strip() life is short!# 5.2 括號(hào)內(nèi)指定字符,移除首尾指定的字符>>> str2 = "**tony**" >>> str2.strip("*") tony# 6.切分split# 6.1 括號(hào)內(nèi)不指定字符,默認(rèn)以空格作為切分符號(hào)>>> str3="hello world">>> str3.split()["hello", "world"]# 6.2 括號(hào)內(nèi)指定分隔字符,則按照括號(hào)內(nèi)指定的字符切割字符串>>> str4 = "127.0.0.1">>> str4.split(".") ["127", "0", "0", "1"] # 注意:split切割得到的結(jié)果是列表數(shù)據(jù)類型# 7.循環(huán)>>> str5 = "今天你好嗎?">>> for line in str5: # 依次取出字符串中每一個(gè)字符... print(line)...今天你好嗎?
重點(diǎn)掌握strip, lstrip, rstriplower(), upper()startswith, endswith格式化輸出之formatformat的其他使用方式split,rsplitjoinreplaceisdigit1.strip,lstrip,rstripstr1="###Erfd###"print(str1.strip("#"))左右兩邊print(str1.lstrip("#"))左邊print(str1.rstrip("#"))右邊ErfdErfd######Erfd
2.lower(),upper()str2="saEFDfef"print(str2.lower())#小寫print(str2.upper())#大寫saefdfefSAEFDFEF
3.startswith,endswith# startswith()判斷字符串是否以括號(hào)內(nèi)指定的字符開頭,結(jié)果為布爾值True或False# endswith()判斷字符串是否以括號(hào)內(nèi)指定的字符結(jié)尾,結(jié)果為布爾值True或Falsestr3 = "tony jam"print(str3.startswith("t"))print(str3.endswith("t"))TrueFalse
4.格式化輸出format之前我們使用%s來做字符串的格式化輸出操作,在傳值時(shí),必須嚴(yán)格按照位置與%s一一對(duì)應(yīng),而字符串的內(nèi)置方法format則提供了一種不依賴位置的傳值方式str4="name:{name},age:{age}".format(age=18,name="sfv")print(str4)name:sfv,age:18str4="name:{name},age:{age},age:{age},age:{age},age:{age}".format(age=18,name="sfv")print(str4)name:sfv,age:18,age:18,age:18,age:18
其他方式# 類似于%s的用法,傳入的值會(huì)按照位置與{}一一對(duì)應(yīng)str4="name:{},age:{}".format("asdf",12)print(str4)name:asdf,age:12# 把format傳入的多個(gè)值當(dāng)作一個(gè)列表,然后用{索引}取值str4="name:{0},age:{1}".format("asdf",12)print(str4)str4="name:{1},age:{0}".format(12,"dsdf")print(str4)name:dsdf,age:12
5.split,rsplit# split會(huì)按照從左到右的順序?qū)ψ址M(jìn)行切分,可以指定切割次數(shù)str5="c:/sdw/ds/dw/ac/sd.txt"print(str5.split("/",1))["c:", "sdw/ds/dw/ac/sd.txt"]# rsplit剛好與split相反,從右往左切割,可以指定切割次數(shù)str5="c:/sdw/ds/dw/ac/sd.txt"print(str5.rsplit("/",1))["c:/sdw/ds/dw/ac", "sd.txt"]
6.join# 從可迭代對(duì)象中取出多個(gè)字符串,然后按照指定的分隔符進(jìn)行拼接,拼接的結(jié)果為字符串print("#".join("sefdgs"))# 從字符串"hello"中取出多個(gè)字符串,然后按照%作為分隔符號(hào)進(jìn)行拼接s#e#f#d#g#sprint("|".join(["tony","18","read"]))# 從列表中取出多個(gè)字符串,然后按照*作為分隔符號(hào)進(jìn)行拼接tony|18|read
7.replace# 用新的字符替換字符串中舊的字符str7 = "my name is tony, my age is 18!"print(str7.replace("18","34"))my name is tony, my age is 34!# 只把一個(gè)my改為MYstr7 = "my name is tony, my age is 18!"print(str7.replace("my","MY",1))MY name is tony, my age is 18!
8.isdigit# 判斷字符串是否是純數(shù)字組成,返回結(jié)果為True或Falsestr8="235235"print(str8.isdigit())Truestr8="235223sf35"print(str8.isdigit())False
了解部分1.find rfindfind:從指定范圍內(nèi)查找子字符串的起始索引,找得到則返回?cái)?shù)字1,找不到則返回-1fate="tonr asr dfeei sccof"print(fate.find("o",0,13))12.index:同find,但在找不到時(shí)會(huì)報(bào)錯(cuò)
3.countcount:統(tǒng)計(jì)字符串在大字符串中出現(xiàn)的次數(shù)fate="tonr asr dfeei sccof"# print(fate.find("o",0,13))print(fate.count("o"))2
4.center,ljust,rjust,zfillname="sdacd"print(name.center(30,"-"))#居中print(name.rjust(30,"@"))#右對(duì)齊print(name.ljust(30,"#"))#左對(duì)齊print(name.zfill(50))#右對(duì)齊0補(bǔ)充------------sdacd-------------@@@@@@@@@@@@@@@@@@@@@@@@@sdacdsdacd#########################000000000000000000000000000000000000000000000sdacd
5.expandtabsname = "tony\thello" # \t表示制表符(tab鍵)print(name)tonyhello
6.captalize,swapcase,titlebuxiangxei="hello xIanG mo yu"print(buxiangxei.capitalize())#首字母大寫print(buxiangxei.swapcase())#大小寫反轉(zhuǎn)print((buxiangxei.title()))#每個(gè)首字母大寫Hello xiang mo yuHELLO XiANg MO YUHello Xiang Mo Yu
7.is數(shù)字類型 #isdigit() 方法檢測(cè)字符串是否只由數(shù)字組成,只對(duì) 0 和 正數(shù)有效。# isdecimal() 方法檢查字符串是否只包含十進(jìn)制字符。這種方法只存在于unicode對(duì)象。#IsNumeric 函數(shù)返回一個(gè)布爾值,指示指定的表達(dá)式是否可作為數(shù)字來計(jì)算。如果表達(dá)式作為數(shù)字來計(jì)算則返回 True ,否則返回 Falsenum1 = b"4" #bytesnum2 = u"4" #unicode,python3中無需加u就是unicodenum3 = "四" #中文數(shù)字num4 = "Ⅳ" #羅馬數(shù)print(num1.isdigit())print(num2.isdigit())print(num3.isdigit())print(num4.isdigit())#isdecimal:uncicode(bytes類型無isdecimal方法)print(num2.isdecimal())print(num3.isdecimal())print(num4.isdecimal())#isnumberic:unicode,中文數(shù)字,羅馬數(shù)字(bytes類型無isnumberic方法)print(num2.isnumeric())print(num3.isnumeric())print(num4.isnumeric())# 三者不能判斷浮點(diǎn)數(shù)num5="4.5"print(num5.isdecimal())print(num5.isdigit())print(num5.isnumeric())TrueTrueFalseFalseTrueFalseFalseTrueTrueTrueFalseFalseFalse總結(jié):最常用的是isdigit,可以判斷bytes和unicode類型,這也是最常見的數(shù)字應(yīng)用場(chǎng)景如果要判斷中文數(shù)字或羅馬數(shù)字,則需要用到isnumeric。
列表# 定義:在[]內(nèi),用逗號(hào)分隔開多個(gè)任意數(shù)據(jù)類型的值l1 = [1,"a",[1,2]] # 本質(zhì):l1 = list([1,"a",[1,2]])# 但凡能被for循環(huán)遍歷的數(shù)據(jù)類型都可以傳給list()轉(zhuǎn)換成列表類型,list()會(huì)跟for循環(huán)一樣遍歷出數(shù)據(jù)類型中包含的每一個(gè)元素然后放到列表中>>> list("wdad") # 結(jié)果:["w", "d", "a", "d"] >>> list([1,2,3]) # 結(jié)果:[1, 2, 3]>>> list({"name":"jason","age":18}) #結(jié)果:["name", "age"]>>> list((1,2,3)) # 結(jié)果:[1, 2, 3] >>> list({1,2,3,4}) # 結(jié)果:[1, 2, 3, 4]使用# 1.按索引存取值(正向存取+反向存取):即可存也可以取 # 1.1 正向取(從左往右) my_friends=["tony","jason","tom",4,5]print(my_friends[0])tony# 1.2 反向取(負(fù)號(hào)表示從右往左)print( my_friends[-1])# 1.3 對(duì)于list來說,既可以按照索引取值,又可以按照索引修改指定位置的值,但如果索引不存在則報(bào)錯(cuò)my_friends[1] = "martthow"print(my_friends)["tony", "martthow", "jason", 4, 5]
# 2.切片(顧頭不顧尾,步長)# 2.1 顧頭不顧尾:取出索引為0到3的元素print(my_friends[0:4])["tony", "jason", "tom", 4]# 2.2 步長:0:4:2,第三個(gè)參數(shù)2代表步長,會(huì)從0開始,每次累加一個(gè)2即可,所以會(huì)取出索引0、2的元素print(my_friends[0:4:2])["tony", "tom"]#3.長度print(len(my_friends))5
# 4.成員運(yùn)算in和not inprint("tony" in my_friends)Trueprint("xxx" not in my_friends)True
#5.添加#5.1 append()列表尾部追加元素l1 = ["a","b","c"]l1.append("d")print(l1)["a", "b", "c", "d"]# 5.2 extend()一次性在列表尾部添加多個(gè)元素l1.extend(["a","b","c"])print(l1)# 5.3 insert()在指定位置插入元素l1.insert(0,"first") # 0表示按索引位置插值print(l1)["first", "a", "b", "c", "alisa", "a", "b", "c"]
# 6.刪除# 6.1 dell = [11,22,33,44]del l[2] # 刪除索引為2的元素print(l)# 6.2 pop()默認(rèn)刪除列表最后一個(gè)元素,并將刪除的值返回,括號(hào)內(nèi)可以通過加索引值來指定刪除元素l = [11,22,33,22,44]res=l.pop()print(res)44res=l.pop(1)print(res)22# 6.3 remove()括號(hào)內(nèi)指名道姓表示要?jiǎng)h除哪個(gè)元素,沒有返回值l = [11,22,33,22,44]res=l.remove(22) # 從左往右查找第一個(gè)括號(hào)內(nèi)需要?jiǎng)h除的元素print(res)None
7.reverse()顛倒列表內(nèi)元素順序l = [11,22,33,44]l.reverse()print(l)[44,33,22,11]
# 8.sort()給列表內(nèi)所有元素排序# 8.1 排序時(shí)列表元素之間必須是相同數(shù)據(jù)類型,不可混搭,否則報(bào)錯(cuò)l = [11,22,3,42,7,55]l.sort()print(l)[3, 7, 11, 22, 42, 55] # 默認(rèn)從小到大排序l = [11,22,3,42,7,55]l.sort(reverse=True) # reverse用來指定是否跌倒排序,默認(rèn)為Falseprint(l)[55, 42, 22, 11, 7, 3]# 8.2 了解知識(shí)# 我們常用的數(shù)字類型直接比較大小,但其實(shí),字符串、列表等都可以比較大小,原理相同:都是依次比較對(duì)應(yīng)位置的元素的大小,如果分出大小,則無需比較下一個(gè)元素,比如l1=[1,2,3]l2=[2,]print(l2>l1)# 字符之間的大小取決于它們?cè)贏SCII表中的先后順序,越往后越大 s1="abc" s2="az"print(s2>s1)# 所以我們也可以對(duì)下面這個(gè)列表排序l = ["A","z","adjk","hello","hea"] l.sort()print(l)
# 9.循環(huán)# 循環(huán)遍歷my_friends列表里面的值my_friends=["tony","jack","jason",4,5]for line in my_friends:print(line) "tony""jack""jason"45
標(biāo)簽:
河南省夏播基本結(jié)束 累計(jì)播種9000萬畝左右
河南開展巨災(zāi)保險(xiǎn)試點(diǎn)工作 鄭州等6個(gè)省轄市先行先試
全國疫情最新消息|6月27日新增本土確診1例、本土無癥狀21例
旱情得到緩解!河南省7月上旬前將轉(zhuǎn)為多雨期
河南瓦店遺址發(fā)現(xiàn)夏代早期大型祭祀遺跡
農(nóng)田必須是良田!河南糧食總產(chǎn)量連續(xù)5年穩(wěn)定在1300億斤左右
河南:“十三五”時(shí)期,基本養(yǎng)老保險(xiǎn)參保人數(shù)達(dá)7504.67萬人、參保率達(dá)94.77%
河南“五星”支部創(chuàng)建省級(jí)示范培訓(xùn)班7月4日開班
- 01 河南瓦店遺址發(fā)現(xiàn)夏代早期大型祭祀遺跡
- 02 河南省人民政府關(guān)于印發(fā)河南省深化普通高等學(xué)??荚囌猩C合改革實(shí)施方案的通知
- 03 河南省十三屆人大常委會(huì)第三十三次會(huì)議舉行
- 04 全國疫情最新消息|6月27日新增本土確診1例、本土無癥狀21例
- 05 6月27日河南無新增本土確診病例、無癥狀感染者
- 06 點(diǎn)贊!河南省政府通報(bào)表揚(yáng)這15個(gè)單位
- 07 旱情得到緩解!河南省7月上旬前將轉(zhuǎn)為多雨期
- 08 樓陽生在全省防汛視頻調(diào)度會(huì)上強(qiáng)調(diào) 始終不麻痹不僥幸不猶豫不懈怠 以保過程降雨安全保汛期安全 王凱出席
- 09 鄭州:8所民辦初中計(jì)劃29日進(jìn)行電腦派位
- 010 河南瓦店遺址發(fā)現(xiàn)夏代早期大型祭祀遺跡