博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
字符串
阅读量:4544 次
发布时间:2019-06-08

本文共 9380 字,大约阅读时间需要 31 分钟。

内容概要     1. 基本数据类型概况         1, int 整数         2. str 字符串         3. bool 布尔值         4. list 列表. 一般存放大量的数据 ["门神xxxx", "风扇哥xxxx", 元素]         5. tuple 元组. 只读列表, 只能看啥也不能干. (元素, 元素)         6. dict 字典. {"风扇哥":"王伟哲", "wlh": "王力宏"}         7. set  集合 {"风扇哥", "wlh"}. 不重复         8. bytes 一堆字节. 最小数据单元     2. int类型的相关操作.         数字没办法执行其他操作. 操作只有+-*/, //, %, **         8bit => 1byte         bit_length() 二进制长度
1 a = 5  # 1 + 1 = 10 + 1 = 11 + 1 =  100 + 1 = 1012 print(a.bit_length()) # 计算一个数字的二进制长度. 没啥用
View Code

 

3. bool类型的操作. 基本类型转换的问题         bool类型没有操作.         类型转换         结论一: 想把xxx转化成yy类型. yy(xxx)         结论二: 能够表示False的数据: 0, "", [], {}, set(), tuple(), None, False
1 # a = 10 2 # print(type(a)) # 
3 # d = str(a) # 把数字转换成str 4 # print(type(d)) #
5 6 7 # b = "10" 8 # print(type(b)) #
9 # c = int(b) # b扔到int() 得到的结果就是一个int10 # print(type(c)) #
11 12 # 字符串 => 数字 int()13 # 数字 = > 字符串 str()14 # x => y类型 y(x)15 # 结论一: 想把xxx数据转化成yy类型的数据. yy(xxx)16 17 # 把数字转化成bool18 # 0是False, 非零是True19 # a = 1020 # print(bool(a)) # True21 # print(bool(1)) # True22 # print(bool(0)) # False23 # print(bool(-1)) # True24 25 # 空字符串 表示False26 # print(bool("哈哈")) # True27 # print(bool(" ")) # 空格是True28 # print(bool("")) # 空字符串是false29 30 # 结论二: 所有的空都可以表示False31 # print(bool([])) # False 空列表32 # print(bool({})) # False 空字典33 # print(bool(set())) # False 空集合34 #35 # # None 空, 真空.36 # print(bool(None))37 38 # while 1: # while True: # 底层一定会有 True => 1的过程,所以使用1要优于True39 # print("还我钱")
View Code

 

4. str 认识字符串(重点, 多)         字符: 单一的文字符号         字符按照固定的顺序连成串         被' 或者" 或者''' 或者"""括起来的内容         索引 就是编号, 顺序             从0开始         切片             s[start:end:step]                 start:开始                 end: 结束  取不到                 step: 步长, 控制方向(决定了 end 往哪个方向去取值). 每xx个取一个
1 # - 倒数 2 #   -8-7-6-5-4-3-2-1 索引还可以倒着数 . 起始位置 -1 3 #    0 1 2 3 4 5 6 7  索引 4 # s = "今天中午吃胡辣汤" 5  6 # 索引使用[下标]获取数据,从0开始 7 # print(s[3]) 8 # print(s[2]) 9 10 # print(s[-3])11 # print(s[-6])12 13 14 # 切片, 从一个字符串中截取出一部分字符串15 # [start: end] 顾头不顾尾   end取不到16 # s = "中间的,你们为什么不说话.难受"17 # print(s[3:7]) # ,你们为18 # print(s[5:9]) # 们为什么19 # print(s[-3: -7]) # 切不到东西, 默认是从左往右切20 # ##所以如果想要取到值应该满足下面的条件21 #       步长是正数,左小右大,从左边往右去取值22 #       步长是负数,左大右小,从右边往左去取值23 # print(s[-7: -3])  # 么不说话24 # print(s[:6]) # 从头开始切25 # print(s[6:]) # 切到末尾26 # print(s[:])  # 从开始到结束27 28 29 # # 步长step,  默认是1 每xxx个取一个30 # # [start: end: step]31 # s = "abcdefghijklmn"32 # print(s[::2])#acegikm33 # print(s[1:5:3])#be34 # print(s[7:3]) # 取不到值. 默认步长1 从左往右切35 # print(s[7:3:-1])  # hgfe  step是负数,从右往左切,结果也是从右往左的36 # # step可以控制方向. 如果step是正数. 从左往右切. 如果是负数 . 从右往左切.结果也与 step 的方向是一致的37 # print(s[-1:-8: -2]) # nljh38 39 # s = "默念哥没吃饭哥不说话"40 # print(s[3::-3]) # 这里的[3:]由于step是负值,所以是往左边的方向取到头的,结果是默念哥没     最终s[3::-3]的结果是没默41 # print(s[::-1])#话说不哥饭吃没哥念默    这里就是由于 step 是-1,所以全部的字符倒着取.可以用来判断一个字符串是否是回文42 43 # 判断一句话是否是回文44 # s = "黄山落叶松叶落山黄"45 # s2 = s[::-1] # 翻过来46 # if s == s2:47 #     print("是回文")48 # else:49 #     print("不是回文")
View Code
一大波操作.(△下面8个标注是重点,需要记忆的)           字符串是不可变的数据类型. 不论如何操作.对原来的字符串是不会有影响的             1, upper() 转换成大写. 忽略大小写             2, strip() 去掉左右两端的空白(包括空格, \t 以及\n).  所有用户输入的内容都要去空白                 s.strip()去除两端的空格  s.strip('a')去除两端的a             3, replace(old, new) 把old替换成new(所有的都替换)                 replace(old, new,2)只替换2个             4, split() 字符串切割 ##切出来的结果会放在列表中                 s.split("哈") 根据所有的'哈'进行切割                 s.split("哈",2) 根据前2个'哈'进行切割             5, startswith() 判断是否以xxx开头             6, find() 查找, 找不到返回-1             7, isdigit() 判断是否是数字组成             8, len() 求长度
1 # s = "abcdefg"  2 # s1 = s.capitalize() # 把首字母变成大写, 返回给你一个新的字符串  3 # print(s) # 字符串不可变. 原字符串是不会发生改变的  4 # print(s1)  5   6 # s = "alex sb dsb wusir bi1gsb"  7 # s2 = s.title() # 标题. 把字符串中每个单词(单词:每个被特殊字符(特殊字符:所有的非字母就是特殊字符,包括数字和中文)隔开的字⺟就是单词)的首字母大写  8 # print(s2)  9  10 ##大写 11 # s = "alex sb dsb bigsb" 12 # s3 = s.upper() # 所有的字母变成大写字母(重点)  #这个方法对所有的字母(比如欧文)都完全没问题 13 # print(s3) 14  15 # while True: 16 #     content = input("请输入你要说的话 输入Q退出:") 17 #     if content.upper() == "Q": # 当需要忽略大小写的时候 18 #         break 19 #     print("你想对打野说", content) 20  21 # # 验证码 22 # verifyCode = "aEmn" 23 # veri = input("请输入你的验证码(%s)" % verifyCode) 24 # if veri.upper() == verifyCode.upper(): # 忽略掉用户输入的大小写 25 #     print("验证码是正确的") 26 # else: 27 #     print("验证码错误") 28  29 # # 小写 30 # s = "Alex Is Not A GooD mAN" 31 # s4 = s.lower() # 所有的字母变成小写字母 有问题的. 对欧洲特殊文字是不识别的 32 # print(s4) 33 ##小写 34 # s = "Alex Is Not A GooD mAN" 35 # s5 = s.casefold() # 所有的字母变成小写字母,用法与lower()相同   支持特殊文字 36 # print(s5) 37  38 s2 = "БBß" # 俄美德 39 # print(s2) 40 # print(s2.lower()) 41 print(s2.casefold()) 42  43 ##大写字母变成小写字母,小写变大写 44 # s = "wusir 昨天 Love 了 女神. guo fen 了" 45 # print(s.swapcase()) # 大变小, 小变大 46  47  48 # center()  中间. 居中 49 # s = "alex" 50 # s6 = s.center(10, "*") # 长度, 用_填充##把长度空间拉长成10,把原来的字符串放在中间,其余位置补* 51 # print(s6) 52  53 # s = "\n\nalex    is      sb      " 54 # print(s) 55 # s7 = s.strip() # 去掉左右两端的空白(空格, \t, \n), 中间的内容不会动 56 # print(s7) 57  58 # 应用##所有的用户输入都应该去空(左右两端的空白) 59 # uname = input("请输入你用户名:").strip()  # 干掉用户的空格 60 # upws = input("请输入你的密码:").strip()  # 干掉用户的空格 61 # if uname =="alex" and upws == "123": 62 #     print("登录成功") 63 # else: 64 #     print("登录失败") 65  66 # s = "sbalexsbwusirsb" 67 # print(s.strip("sb")) # 去掉左右两端的sb 68  69 # 字符串替换 70 # s = "       good alex good wusir good 大虾 good 胡辣汤     " 71 # s8 = s.replace("good", "sb")     # 把s中的good替换成sb 72 # print(s8) 73 # s9 = s.replace(" ", "") 74 # print(s9) 75 # s10 = s.replace("good", "sb", 2) # 字符串替换2次 76 # print(s10) 77  78 # 字符串切割 79 s = "alex 哈昨天哈给我们涨工资了?哈 不可能" 80 # lst = s.split("alex") # 切出来的结果会放在列表中, 刀的位置会损失掉(根据谁进行切割,哪里就是刀的位置,)刀如果把头了. 一定会产生空字符串(即:如果切割符在左右两端. 那么一 定会出现空字符串.深坑请留留意) 81 lst = s.split("爱") #根据'爱'去切割,原字符串中不存在'爱',也不会报错 82 lst = s.split("哈",2)#根据'哈'切割,但是只切割2次(即只根据前面两个'哈'去切割) 83 print(lst) 84  85  86 # 格式化输出 87 # name = "alex" 88 # age = 18 89 # hobby = "wusir" 90 # 91 # print("领导叫%s, 今年%d, 喜欢%s" % (name, age, hobby)) 92 # print("领导叫{}, 今年{}, 喜欢{}".format(name, age, hobby)) 93 # print("领导叫{1}, 今年{0}, 喜欢{2}".format(name, age, hobby)) # 程序员数数从0开始 94 # print("领导叫{na}, 今年{age}, 喜欢{hobby}".format(na = name, age = age, hobby = hobby)) 95 # 96 # print(f"领导叫{name}, 今年{age}, 喜欢{hobby}")##老师推荐这种格式化方法 97  98  99 # 判断字符串是否以xxx开头100 # s = "java_python_区块链_大数据"101 # print(s.startswith("python")) # 判断xxx是否以xxx开头.102 # name = input("请输入你的名字:")  # 张开 致青春103 # if name.startswith("张"):104 #     print("领钱")105 # else:106 #     print("不领钱")107 108 # 以xxx结尾 endwith()109 110 111 # 数数112 # s = "lexa is big sb"113 # print(s.count("i"))  # 计数114 115 ##find()和 index()的用法是一样的,都是返回索引的位置,只不过当要查找的内容不存在的话,使用find不会报错,而inde 是会报错的116 # find() 查找, 如果存在. 返回索引. 如果不存在返回-1117 # s = "滋滋冒油的猪蹄子"118 # print(s.find("牛")) # 用这个##这里是与 index 相比较而言的,因为不会报错119 # #ret7 = s.find("a", 0, 3) # 切⽚片找 [0,3]120 # #print(ret7)121 # index() 如果找到了返回索引. 找不到. 报错122 # print(s.index("牛"))123 124 # s = "alexwusir"125 # print(s.isalpha()) # 是否是由基本的文字组成. 是否是由字母组成(包括中文)126 127 128 # 判断是否是数字组成129 # s = "123456798一" # digit 数字   %d130 # print(s.isdigit()) # 阿拉伯数字131 132 # s = "123456789一二三壹仟贰佰壹拾伍叁"133 # print(s.isnumeric()) # number134 135 136 # s = "我叫周润发,我喜欢DNF"137 # print(len(s)) # 字符串长度, 内置函数138 # ##老师说内置函数都不用像上面那样(例如 s.trip())前面需要加个点,那前面加个点调用的是什么?不懂139 140 141 # 把一句话中的每一个字符拿到142 # s = "风扇哥门神灯神哈哈我的天哪" # len(s)143 #144 # # 用while循环. 获取到每一个字符145 # i = 0  # 索引146 # while i < len(s):147 #     print(s[i])148 #     i += 1149 150 # for循环来遍历字符串151 # for: 循环152 # c: 变量153 # in : 固定的154 # s: 你要遍历的内容155 # for c in s:  # 把字符串s中的每一个元素拿到赋值给前面的c156 #     print(c)157 158 # for循环有一个先决条件. 必须是可迭代对象.159 # 遍历钱包160 # 缺点: 无法看到字符的索引.161 '''162 for 变量 in 可迭代对象:163     循环体(break, continue)164 '''
View Code
for循环遍历字符串         for 变量 in 可迭代对象:             循环体         for c in s: # c: charactor(字符) s: string             print(c)
1 # 把一句话中的每一个字符拿到 2 # s = "风扇哥门神灯神哈哈我的天哪" # len(s) 3 # 4 # # 用while循环. 获取到每一个字符 5 # i = 0  # 索引 6 # while i < len(s): 7 #     print(s[i]) 8 #     i += 1 9 10 # for循环来遍历字符串11 # for: 循环12 # c: 变量13 # in : 固定的14 # s: 你要遍历的内容15 # for c in s:  # 把字符串s中的每一个元素拿到赋值给前面的c16 #     print(c)17 18 # for循环有一个先决条件. 必须是可迭代对象.19 # 遍历钱包20 # 缺点: 无法看到字符的索引.21 '''22 for 变量 in 可迭代对象:23     循环体(break, continue)24 '''
View Code

5.

内容回顾小结:     1. 基本数据类型概述         int 整数         str 字符串         bool 布尔值  True, False         list 列表 []         tuple 元组 ()         dict 字典 存储key:value         set 集合 不重复         bytes 字节     2. int 整数         bit_length()  求二进制长度     3. bool 类型         类型转换         结论一: 把x转化成y类型. y()         结论二: 能表示False的数据有: 0, None, "", [], tuple(), set(), {}     4. str 字符串         索引: 下标从0开始的数字. 指示的是字符串中的每一个字符         切片: 从源字符串中截取一部分内容作为新字符串             s[start: end: step]             start: 开始             end: 结束. 取不到             step: 步长, 默认是1. 每step取一个. 通过符号来控制方向. +从左往右, -从右往左         一大波操作:             1. upper() 转化成大写             2. strip() 去掉两端的空白(空格, \n, \t)             3. replace(old, new) 把字符串中的old替换成new             4. split() 字符串切割. 返回列表             5. startswith() 判断是否以xxx开头             6. find() 查找 如果找不到返回-1             7. isdigit() 判断是否是数字组成             8. len() 字符串长度         字符串的 遍历(迭代)         for c in s:             print(c)         迭代:可以一个一个的往外拿         for 变量 in 可迭代对象:

转载于:https://www.cnblogs.com/liangxiaoji/p/10056524.html

你可能感兴趣的文章
并发编程学习总结
查看>>
Xamarin.Android 上中下布局
查看>>
VS Code使用记录
查看>>
locust参数化(数据库取值)
查看>>
Google Protocol Buffers浅析(三)
查看>>
.net core 中使用Google的protoc
查看>>
Spring Cloud和Spring Boot的区别
查看>>
jquery实现图片上传前本地预览
查看>>
C# — 题库答案汇总
查看>>
docker居然需要3.10以上的内核
查看>>
Win10下安装zookeeper
查看>>
客户端用JavaScript填充DropDownList控件,服务器端读不到值
查看>>
Dubbo源码学习--服务是如何引用的
查看>>
【转】C#安装字体到系统
查看>>
Android视频播放之VideoView
查看>>
非对称加密
查看>>
位运算巧用
查看>>
display:flex布局
查看>>
利用反射跟自定义注解拼接实体对象的查询SQL
查看>>
JQuery Ajax Options
查看>>