Python的基础类型(int,bool,str):
1.int -------> 整形:主要用力进行数字计算
2.string ------>字符串:可以保存少量数据并进行相关的操作
3.bool-------->布尔型:判断真假 true(真),false(假)
4.list--------->列表:存储大量数据,用[]来表示
5.tuple------->元组:不可以改变,用()表示
6.dict---------->字典:保存键值对,一样保存大量数据
7.ste----------->集合:保存大量数据不可以重复,也就是不保存value的dict
整数(int)
在Python中整数都是int型,但是在python2中如果数据量比较大.会使用long类型,在python3中不存在long类型,整数可以进行的操作
bit_length().计算整数在内存中占用的二进制长度
布尔值(bool):
取值只有ture和false,bool没有操作
转换问题:
str--------> int(str) str字符串类转换成数字类型
int-------->str(int) int数字类型转换成字符串类型
int--------->boot(int) int转换成布尔型,0是false,非0是true
bool------>int(bool) bool转换为数字类,true是1,fase是0,只存在1和0
str--------->bool(str) 空字符串是false,不空是true
bool------->str(bool) 把bool转成相应的值
元祖------->list(tuple) 把元祖转换成列表
列表------->tuple(list) 把列表转换成元祖
list------->str.join(list) 把列表转换成字符串
str-------> str.split() 把字符串切割为列表
转换成False的数据: 0,'',None,[],(),{},set() ==> False
字符串(str):
把字符连接到一起称作字符串:字符串是可以先加的:(字符串+字符串),在python中',",''',"""引起来的内容成为字符串
4.1:切片和索引
1.索引,索引就是下标记,切记,下标从0开始
# 012345678 name = "python最牛逼" print (name[0]) #获取p print (name[1]) #获取y print (name[2]) #获取t print (name[3]) #获取h print (name[4]) #获取o print (name[5]) #获取n print (name[6]) #获取最 print (name[7]) #获取牛 print (name[8]) #获取逼 print (name[9]) #没有9,越界了会报错 print(name[9]) IndexError: string index out of range #索引错误:字符串索引超出范围 print(name[-1]) #表示倒数第一个 print(name[-2]) #表示倒数第二个
2.切片,我们可以使用下标来截取部分字符串内容
语法:str[start:end]
规则:顾头不顾尾,从start(开始)去截取,截取到end,最后一个则不截取
name =python最牛逼 print(name[0:3]) #从0获取到3,不包括3 结果:pyt print(name[6:8]) #从6获取到8,不包含8 结果:最牛 print(name[6:9]) #最大是8,根据顾头不顾尾,想取到8必须给9 结果:最牛逼 print(name[6:10]) #如果右边已经过了最大值,相当于取值到最后,切片超值不报错 print(name[4:]) #从第4位取值到最后
print(name[-1:-5]) #从-1到-5是获取不到结果的,因为从-1向右数,是数不到-5的 print(name[-5:-1]) #从倒数第5个向右数,数到倒数第一个,结果on最牛 print(name[-5:]) #从倒数第5个向右数,数到最后包括最后一位,结果:on最牛逼 print(name[-1:]) #这个是取到最后一个,结果:逼 print(name[:]) #原样输出
跳着截取
#跳着取:步长 name = "python最牛逼" print(name[1:5:2]) #从第一个开始取,取到第五个,每两个取一个 结果: yh, 分析: 1:5=> ytho => yh print(name[:5:2]) #从头开始到第五个. 每两个取一个 print(name[4::2]) #从4开始取,取到最后,每两个取一个 print(name[-5::2]) #从倒数第五个开始取到最后,每两个值娶一个 print(name[-1:-5]) #-1到-5没有值,因为是从左往右取的 print(name[-1:-5:-1]) #步长是-1,这时候就是从右往左取值 print(name[-5::-3]) #从倒数第五个开始,到最开始,没3个值娶一个
步长:如果是整数,则从左往右,如果是负数从右往左数,默认是1
切片语法:str[start:end:step] start开始 end结束 step步长
4.2字符串的相关方法,字符串是不可变的对象,所以任何操作对原字符串是不会有影响的
1.大小写转来转去
name = "i am a newbest" #capitalize print (name.capitalize()) #首字母大写,如果当前首字母为大写那么执行这个就变成小写 #lower print (name.lower()) #全部转换为小写 #upper print(name.upper()) #全部转换为大写 #swapcase print(name.swapcase()) #大小写互相转换 #casefold print (name.casefold()) # 转换成小写, 和lower的区别: lower()对某些字符支持不够好. casefold()对所有字母都有效. 比如东欧的一些字母 #title print(name.title()) #每个被特殊字符隔开的首字母大写,中文也算是特殊字符 #应用,身份验证输入验证码是否正确 time = "zDxY" user1 = input("请输入验证码") if time.upper() == name.upper(): print("验证成功") else: print("验证失败")
name = "python最牛逼"
name.startswith() #大写转换小写,小写转换大写
name.title() #每个被特殊字符隔开的英文字母大写,中文也算是特殊符号
2.字符串切过来切过去
#字符串是不可改变对象,所有操作都是产生新的字符串返回,如 name = "xiao_liu_源" name.replace("xaio","liu") print (name) #结果xiao_liu_源,你会发现并没有改变 print (name.replace("xaio","liu")) #结果liu_liu_源 n1 = name.replace("xaio","liu") print (n1) #结果liu_liu_源 ############################################### s5 = "周杰伦" name = s5.center(10,"*") #居中 print (name) #结果:***周杰伦**** #除去空格 s7 = " xiao yao name " print(s7.strip()) #除去两边的空格 print(s7.lstrip()) #除去左边的空格 print(s7.rstrip()) #出去右边的空格 #模拟用户登录,忽略用户输入空格 user = input("请输入您的账户":) password = input("请输入您的密码") if user == alix and password == "123": print("登陆成功") else: print("登陆失败") name = "111sdjshfkjsdh111" print (name.strip("111")) #除去两边的111,可以指定元素 #字符替换 name = "xiao_dshk_jfhs_oming_dsjkfhsk_j" print (name.replace("xiao","liu")) #把xiao替换成liu print (name.replace("o","a",2)) #把两个o替换成a,name = "xiaa_dshk_jfhs_aming_dsjkfhsk_j" # 字符串切割 s9 = "alex,wusir,sylar,taibai,eggon" lst = s9.split(",") # 字符串切割, 根据,进行切割 print(lst) s10 = """诗人 学者 感叹号 渣渣""" print(s10.split(" ")) # 用 切割,结果['诗人', '学者', '感叹号', '渣渣'] # 坑 s11 = "银王哈哈银王呵呵银王吼吼银王" lst = s11.split("银王") # ['', '哈哈', '呵呵', '吼吼', ''] 如果切割符在左右两端. 那么一定会出现空字符串.深坑请留意 print(lst)
3.格式化输出:
# 格式化输出 s12 = "我叫%s, 今年%d岁了, 我喜欢%s" % ('sylar', 18, '周杰伦') # 之前的写法 print(s12) s12 = "我叫{}, 今年{}岁了, 我喜欢{}".format("周杰伦", 28, "周润发") # 按位置格式化 print(s12) s12 = "我叫{0}, 今年{2}岁了, 我喜欢{1}".format("周杰伦", "周润发", 28) # 指定位置 print(s12) s12 = "我叫{name}, 今年{age}岁了, 我喜欢{singer}".format(name="周杰伦", singer="周润发", age=28) # 指定关键字 print(s12)
4.查找
s13 = "我叫sylar, 我喜欢python, java, c等编程语言." ret1 = s13.startswith("sylar") # 判断是否以sylar开头 print(ret1) ret2 = s13.startswith("我叫sylar") # 判断是否以我叫sylar开头 print(ret2) ret3 = s13.endswith("语言") # 是否以'语言'结尾 print(ret3) ret4 = s13.endswith("语言.") # 是否以'语言.'结尾 print(ret4) ret7 = s13.count("a") # 查找"a"出现的次数 print(ret7) ret5 = s13.find("sylar") # 查找'sylar'出现的位置 print(ret5) ret6 = s13.find("tory") # 查找'tory'的位置, 如果没有返回-1 print(ret6) ret7 = s13.find("a", 8, 22) # 切片找 print(ret7) ret8 = s13.index("sylar") # 求索引位置. 注意. 如果找不到索引. 程序会报错 print(ret8)
5.条件判断
# 条件判断 s14 = "123.16" s15 = "abc" s16 = "_abc!@" # 是否由字母和数字组成 print(s14.isalnum()) print(s15.isalnum()) print(s16.isalnum()) # 是否由字母组成 print(s14.isalpha()) print(s15.isalpha()) print(s16.isalpha()) # 是否由数字组成, 不包括小数点 print(s14.isdigit()) print(s14.isdecimal()) print(s14.isnumeric()) # 这个比较牛B. 中文都识别.比如一,二,壹, print(s15.isdigit()) print(s16.isdigit()) # 练习. 用算法判断某一个字符串是否是小数 s17 = "-123.12" s17 = s17.replace("-", "") # 替换掉负号 if s17.isdigit(): print("是整数") else: if s17.count(".") == 1 and not s17.startswith(".") and not s17.endswith("."): print("是小数") else: print("不是小数")
6.计算机长度
name = "我是你的眼, 我也是a" yuan = len(name) # 计算字符串的长度 print(ret) #结果 9
注意len是Python的内置函数,所以访问方式也不一样.只需记住len和print一样即可
7.迭代
我们可以使用for循环来便利(获取)字符串中的每一个字符
语法:
for 变量 in 可迭代对象
name= "大家好, 我是VUE, 前端的小朋友们. 你们好么?" index = 0 while index < len(s19): print(s19[index]) # 利用索引切片来完成字符的查找 index = index + 1
# for循环, 把s19中的每一个字符拿出来赋值给前面的c name = "大家好, 我是VUE, 前端的小朋友们. 你们好么?" for c in name: print(c) #in有两种方法: 1.在for中,是把每一位元素获取到赋值给前面的变量 2.不在for中.判断xxxx是否出现在str中 print('VUE' in name) #练习,计算机在字符串"I am sylar, I'm 14 years old, I have 2 dogs!" xiao = "I am sylar, I'm 14 years old, I have 2 dogs!" count = 0 for c in xiao: if c.isdigit(): count = count+1 print(count)
字符串的转换:
li = ["李嘉诚", "麻花藤", "郭海峰", "刘嘉玲"] s = "_".join(li) print(s) #结果 :李嘉诚_马化腾_郭海峰_刘嘉玲 li = "黄花大闺女" s = "_".join(li) print(s) #结果:黄_花_大_贵_女