003-python基础-字符类型
基本数据类型(int,bool,str)
1.基本数据数据类型:
int 整数
str 字符串. 一般不存放大量的数据
bool 布尔值. 用来判断. True, False
list 列表.用来存放大量数据, []表示. 里面可以装各种数据类型.
tuple 元组. 只读列表. () 表示
dict 字典. {key:value}
set 集合. 不重复
2. int类型
bit_length() 返回一个数的二进制长度
a = 5 # 0 1 10 11 100 101 print(a.bit_length())
3. bool类型
布尔只有两个值. True,False. 一般是没有什么操作的.
类型转换的问题:
想把xx转换成yy. yy(xx)
可以表示False的内容:0, "", [], tuple(), {}, None
所有的空都是False. 所有的非空是True
a = 10 print(type(a)) s = str(a) print(type(s)) int(s) 想把某数据转换成xxx数据类型. xxx(数据) a = 0 # False print(bool(a)) s = "" # 空字符串是false print(bool(s)) # True 空的东西是False. 非空的东西是True lst = [1] # 空列表是False print(bool(lst)) dic = {'jj':'林俊杰'} # 空字典是False print(bool(dic)) a = None # 表示空. 真空. print(bool(a)) 所有的空都是False. 所有的非空都是True 想把某数据装换成xxx数据类型. xxx(数据) str => int int(s) int => str str(i) lst => tuple tuple(lst) tuple => list list(tu) while 1: # 死循环 print("alex是个人才") lst = [1,2,3] # 列表 tu = tuple(lst) print(type(tu))
4. str类型 字符串
由',",''', """阔起来的内容就是字符串
字符串是不可变的数据类型.不论你执行任何操作. 源字符串是不会改变的, 每次操作都会返回新字符串
1. 索引和切片
索引从0开始, 使用[下标]可以获取到每一个字符, 还可以倒着数
切片: [起始位置:结束位置:步长]
1. 顾头不顾尾
2. 默认从左到右取值.
3. 当步长为负可以从右往左取值
s = "伊丽莎白鼠" print(s[0]) print(s[1]) print(s[2]) print(s[3]) print(s[4]) print(s[5]) # 索引不能超过边界 print(s[-1]) # 倒数第一个 print(s[-2]) print(s[-3]) print(s[-4]) print(s[-5]) s = "伊丽莎白鼠的溜肥肠还有挖掘机" 切片 [起始位置: 结束位置] 1.顾头不顾尾, 2.从左往右切 print(s[1:3]) # 从1切到3. 但是取不到3 [1,3) print(s[1:]) # 从1开始切. 切到结尾 print(s[:2]) # 从头切到2 print(s[:]) # 从头到尾 print(s[-3:-1]) # 只能从左往右切 给出第三个参数来控制方向,第三个参数叫步长 print(s[-1:-3:-1]) # - 表示反方向. 从右往左切 print(s[4:10:3]) print(s[-3:-9:-2])
2. 字符串相关操作
1. upper() 转换成大写
2. stript() 去掉空白
3. replace(old, new) 把xxx替换成xxxx
4. split() 切割. 返回列表. 用多长的刀. 就要损失掉多少
5. startswith() 判断是否以xxx开头
6. find(), count(), index()
7. len() 字符串长度. python的内置函数
s = "al1ex is a gay and Wu傻sir is A gay too" s1 = s.capitalize() # 把首字母变成大写 print(s1) s2 = s.lower() # 小写 print(s2) s3 = s.upper() # 大写 print(s3) s4 = s.swapcase() # 大小写互换 print(s4) s2 = "БBß" # 俄美德 print(s2) print(s2.lower()) print(s2.casefold()) s5 = s.title() # 把每个单词的首字母大写 print(s5) s = "sb" s1 = s.center(10, "*") # 强行使用*在原字符串左右两端进行拼接. 拼接成10个单位 print(s1) s = " alex is a gay " s1 = s.strip() # 默认去掉空格. 空白\t \n print(s1) username = input("请输入用户名:").strip() password = input("请输入密码:").strip() if username == 'alex' and password =="123": print("成功") else: print("失败") s = "sb alex wusir sb sb taibai taibai sb" print(s.strip("sb")) # 可以指定要去掉的内容 s = "泰坦尼克号, 西虹市首富, 小猪佩奇, 冒险王" s1 = s.replace("冒险王", "西西里的美丽传说") s2 = s.replace("佩奇", "wusir") print(s2) s = "alex_wusir_taibai_ritian" s1 = s.replace("_","") print(s1) s8 = "sylar_alex_taibai_wusir_eggon" # s9 = s8.replace("i", "sb", 2) # 换两次 # print(s9) lst = s8.split("taibai") # 切完的结果是一个列表. 列表中装的是字符串. 用什么切. 就会损失掉什么 print(lst) s = """我家大门常打开 开放怀抱等你 后面是什么歌词 我忘了""" lst = s.split("\n") print(lst) s = "我今天下午要去吃饭饭" lst = s.split("我今天下午要去吃饭饭哈哈哈") # 没切 print(lst) s = "我叫%s, 我今年%s了, 我喜欢%s" % ("周杰伦", "40", "昆凌") print(s) s = "我叫{}, 我今年{}了, 我喜欢{}".format("周杰伦", "40", "昆凌") print(s) s = "我叫{0}, 我今年{1}了, 我喜欢{2}".format("周杰伦", "40", "昆凌") print(s) s = "我叫{name}, 我今年{age}了, 我喜欢{hobby}".format(hobby="周杰伦", age="40", name="昆凌") print(s) s = "alex is a gay" print(s.startswith("tory")) # 以xxx开头 print(s.endswith("girl")) # 以xxx结尾 s = "I have a dream. I want to kill you!" 都可以进行索引范围 print(s.count("dream")) # 计算a在字符串中出现的次数 print(s.find("a")) # 查找xxx在字符串中出现的位置. 只找第一次出现的位置, 没有就返回-1 print(s.index("z")) # 当字符串不存在的时候. 报错 s = "abcdefg1@" print(s.isdigit()) # %d print(s.isalpha()) # 字母 print(s.isalnum()) # 是否由数字和字母组成 s = "壹仟贰佰五十六萬拾" print(s.isnumeric()) 字符串长度, python的内置函数len(), int(), bool(), str(), type() s = "娃哈哈可口可乐" print(len(s)) # 字符串中的字符的个数 s = "王小利刘能赵四" # # 对字符串进行遍历. n = 0 while n < len(s): print(s[n]) n = n + 1 # 迭代 for c in s: # charactor print(c)
3. for循环
for 变量 in 可迭代对象:
循环体, 也存在break和continue
else:
当循环结束的时候会执行
作者: do康解U
出处: https://www.cnblogs.com/David-domain/>
关于作者:专注数据库、Python 开发、ROS、深度学习,请多多赐教!
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出, 原文链接 如有问题, 可邮件(iamkuboy@163.com)咨询.