一、字符串
·字符串就是一串字符,是编程语言中表示文本的数据类型
·在Python 中可以使用一对双引号”??或者一对’?单引号定义一个字符串
???虽然可以使有\”?或者\’?做字符串的转义,但是在实际开发中:
如果字符串内部需要使用”??可以使用’?定义字符串
如果字符串内部需要使用’??可以使用”?定义字符串
·可以使用 索引 获取一个字符串中 指定位置的字符,索引数从0开始计数
·也可以使用for循环遍历 字符串中每一个字符
(注:大多数编程语言中 都是用”?来定义字符串的)
1.1字符串取索引操作如下:
(注:不论是之前学的列表,元组,字典,还是字符串,取索引 后面都是用[ ])
data:image/s3,"s3://crabby-images/96b12/96b1237a67b25a2ae71cb922fb0e56fe2b0e09c6" alt=""
代码:
str1 = "hello python"
print(str1[6])
?输出结果:
data:image/s3,"s3://crabby-images/b45d4/b45d43c45aff024f6fd6a6329f7682f9b9dc7460" alt=""
?(注:在Python 中,空格也是要算一个 索引的)
1.2 字符串的遍历
操作如下:
data:image/s3,"s3://crabby-images/9fcf5/9fcf5b835b65c11205cd18613675542fd6f299a8" alt=""
?代码:
str1 = "hello python"
for str2 in str1:
print(str2)
输出结果:
data:image/s3,"s3://crabby-images/d5514/d551487d97a4ecc74449916655b21e37448ebd40" alt=""
?1.3 字符串的常用操作:
① len ?获取字符串的长度
操作:
data:image/s3,"s3://crabby-images/aea05/aea05231602c5e9c3d81b3723f3c4816f8c4f04e" alt=""
代码:?
hello_str = "hello hello"
print(len(hello_str))
输出结果:
data:image/s3,"s3://crabby-images/aefcc/aefcccd31c73dfd4c3334202aaaed6ae2764fb74" alt=""
?(注:一定要算上空格键)
② count ?统计大字符串中,某一个小字符串出现的次数
操作:
data:image/s3,"s3://crabby-images/da174/da174d7a986ccd7d580f93bb62f8662ecbb2d316" alt=""
?代码:
hello_str = "hello hello"
print(hello_str.count("llo"))
输出结果:
data:image/s3,"s3://crabby-images/3c618/3c61841b10e6a7fb10758327c4a794d27bcc5b19" alt=""
?
③ index ?获取小字符串 第一次出现的索引
操作:
data:image/s3,"s3://crabby-images/c2db1/c2db17df5af1e3a47bb5f79dbb0610431e7a54e5" alt=""
?代码:
hello_str = "hello hello"
# 3.某一个子字符串出现的位置
print(hello_str.index("h"))
print(hello_str.index("o"))
输出结果:
data:image/s3,"s3://crabby-images/ce752/ce752c1b5e2b66ef9dd64ff4423ad859608a4d2b" alt=""
?做了两个子字符串的 代码, h 最开始出现位置是 0 、 o最开始出现的位置是4
1.4 在Python 中 字符串 的 使用方法总结以及归类:
data:image/s3,"s3://crabby-images/7c8cc/7c8ccaeb92452fbdf715e5defb6f56064da3fc39" alt=""
?在Python 中 使用字符串的 方法 是比较多的,下面进行一下归类:
1.4-1
判断类型:凡是以 ?is ?开头的 ?都是表示判断类型的
data:image/s3,"s3://crabby-images/3164b/3164b98d5ba7ebcc1315806426632fd8c16681d1" alt=""
?下面是演练:
演练1:isspace
data:image/s3,"s3://crabby-images/f73de/f73de9f884fd4b597fec7d1b951f3cfa2c0f3b0f" alt=""
?代码:
space_str = " "
print(space_str.isspace())
输出结果:
data:image/s3,"s3://crabby-images/0873b/0873b9276a91a412048221194624db9be0b57696" alt=""
?(注:如果有其他字符,返还结果则是 false)
演练二、判断数字(这个里面有三种判断方法,光看不好理解,所以做一下实际演练)
下面直接三种类型,做一起的演练,方便比较
①全是数字:(注:这三种方法都是不能判断小数的)
data:image/s3,"s3://crabby-images/ce9d5/ce9d531b62f3686c6156158d29f83326307eae3e" alt=""
?代码:
num_str = "156465"
print(num_str.isdecimal())
print(num_str.isdigit())
print(num_str.isnumeric())
输出结果:
data:image/s3,"s3://crabby-images/77f3a/77f3a7e1df84f8d4b80405ad7c43ae1ae8739be1" alt=""
?结论:三种方法都是可以判断纯数字的(注:在我们开发中,最常用的还是第一种,判断纯阿拉伯数字比较常用)
②特殊数字:“①”这个数字是表示我们平时在键盘中无法直接输入,但是可以通过其他的输入法或者特殊方式输入的字符串 ?一般统称为 unicode 字符串
操作:
data:image/s3,"s3://crabby-images/e95fc/e95fc7fd043b13610c91fb9babbdc07a768f1fee" alt=""
?代码:
num_str = "①"
print(num_str.isdecimal())
print(num_str.isdigit())
print(num_str.isnumeric())
输出结果:
data:image/s3,"s3://crabby-images/41c30/41c30ac0fd3358c08132b5eee1bb85298e2394d9" alt=""
?结论:str.isdigit、str.isnumeric 可以判断特殊字符串
③中文数字:
data:image/s3,"s3://crabby-images/8ac39/8ac39d2ca36533441359489aed8840c5fc68322c" alt=""
?代码:
num_str = "二五八万"
print(num_str.isdecimal())
print(num_str.isdigit())
print(num_str.isnumeric())
输出结果:
data:image/s3,"s3://crabby-images/d44d2/d44d216e108e265c7a0dfdb2297d3be30a3575ad" alt=""
结论:str.isnumeric,不仅可以判断特殊字符还可以判断中文数字?
1.4.2 查找和替换类型:
data:image/s3,"s3://crabby-images/953c4/953c4fcb8e397bc29db31c0c1a102f709f6fb2c6" alt=""
?
下面是演练:
data:image/s3,"s3://crabby-images/879ec/879ecb7cfce52cfe4ed1cf034d4979d5fde547e9" alt=""
?代码:
hello_str = "hello world"
print(hello_str.startswith("hello"))
输出结果:
data:image/s3,"s3://crabby-images/658ca/658ca1b23a21f4ff1337842a575750c3df58cfec" alt=""
?
data:image/s3,"s3://crabby-images/996ec/996ec30a1342ba06c6640c655ae6d46f2a3d89a0" alt=""
?代码:
hello_str = "hello world"
print(hello_str.endswith("world"))
输出结果:
data:image/s3,"s3://crabby-images/e4101/e4101940bb0a770e2e641b3b9b219c7e4addd6ea" alt=""
?
data:image/s3,"s3://crabby-images/22ea9/22ea9be26403f8a30dccbf56e2e7bed16b3169db" alt=""
?代码:
hello_str = "hello world"
print(hello_str.find("l"))
print(hello_str.find("A"))
输出结果:
data:image/s3,"s3://crabby-images/7a0bb/7a0bb0ab8ac004b8104d91bffdedb699f3ec946a" alt=""
?注: index 如果查找的字符串不存在,系统会报错,而find 查找字符不存在 会返回-1
data:image/s3,"s3://crabby-images/a6312/a631255be8b095091cbaa21837f229a93f13b9af" alt=""
?代码:
hello_str = "hello world"
print(hello_str.replace("world", "python"))
print(hello_str)
输出结果:
data:image/s3,"s3://crabby-images/fbbc2/fbbc22fecbcb9063778da8c736366c6dc22d51ea" alt=""
(注:#replace 方法执行完成后,会返回一个新的字符串,但是不会修改原有的字符串,所以输出结果会不一样)?
1.4.3?大小写转换类型:
data:image/s3,"s3://crabby-images/ef2d4/ef2d4dbf0b923f3f5030a4d2916d649eaa0befb6" alt=""
?
1.4.4?文本对其类型:
data:image/s3,"s3://crabby-images/e7650/e7650b124431f44a48ba47b420ac8c4ee1325ce3" alt=""
?下面演练的是居中:(其他类型都是类似的)
data:image/s3,"s3://crabby-images/2db5d/2db5dbf5c08e45106344371c3c927a68626ec3ff" alt=""
?代码:
poem = ["静夜思",
"李白",
"窗前明月光",
"疑似地上霜",
"举头望明月",
"低头思故乡"]
for poem_str in poem:
print(poem_str.center(20))
(注:poem_str.center(20) 这个括号里面的20 表示宽度,要填写,要不然系统会报错)
输出结果:
data:image/s3,"s3://crabby-images/038b6/038b651e65177370337de9417c819f151adfe2b4" alt=""
?
1.4.5?去除空白字符类型:
data:image/s3,"s3://crabby-images/2d425/2d425d7939f9ca1a4bfabe6e87e06056ed89ca05" alt=""
练习:
这个是没有做去除空白的代码和输出结果:
data:image/s3,"s3://crabby-images/e5582/e55825827c5cfcfa24d281941ee203b136f1939e" alt=""
?data:image/s3,"s3://crabby-images/4c4db/4c4db0b9210c7bc0ababc74295e3fdb4819f16a9" alt=""
?显示很乱
?下面是做去除空白的演练:
data:image/s3,"s3://crabby-images/16ab1/16ab1c71b416613beb4cb3884d37edaf7c808bb4" alt=""
?代码:
poem = ["\t\n静夜思",
"李白",
"窗前明月光",
"疑似地上霜\n\n",
"举头望明月",
"低头思故乡"]
for poem_str in poem:
#使用strip方法去除字符串的空白
#再使用center方法居中
print(poem_str.strip().center(20))
输出结果:
data:image/s3,"s3://crabby-images/77a07/77a075d4fb7d378c1ecfa37a90bb5fea41d3bd75" alt=""
?(注:上面是把去空白和居中对齐一起操作的)
1.4.6?拆分和连接类型:
data:image/s3,"s3://crabby-images/9d0d1/9d0d153b035588cd56ef8335a5ef16fe4e3fa1b6" alt=""
?演练:
data:image/s3,"s3://crabby-images/8642a/8642af21fdd3b13d3db614cd3a4050696e8a4d77" alt=""
代码:?
poem_str = "静夜思\t 李白\n\t 窗前明月光\n 疑似地上霜\n\n 举头望明月\t\n 低头思故乡"
print(poem_str)
poem_list = poem_str.split()
print(poem_list)
输出结果:
data:image/s3,"s3://crabby-images/b3d4b/b3d4bd325a67d9b8cb8f9b1f37cacf588369cba6" alt=""
?
data:image/s3,"s3://crabby-images/bd6b9/bd6b9fe75ca969bfb9d28527a238b802ab35e991" alt=""
?代码:
poem_str = "静夜思\t 李白\n\t 窗前明月光\n 疑似地上霜\n\n 举头望明月\t\n 低头思故乡"
print(poem_str)
poem_list = poem_str.split()
print(poem_list)
result = " ".join(poem_list)
print(result)
输出结果:
data:image/s3,"s3://crabby-images/113a2/113a22dd1e7137676f222738accd7aabfa058a8b" alt=""
?
1.5 字符串的切片
·切片 方法适用于 字符串、列表、元组
???切片 使用 索引值 来限定范围,从一个大的 字符串 中 切出 小的字符串
???列表 和 元组 都是 有序的 集合,都能够通过索引值 获取到相对应的数据
??字典 是一个无序的集合,使用舰队之 保存数据的
(注:切片时,是不包含结束时,索引值的字符的,切片分为两种 1.顺序:从左往右从 0 开始 2.倒序:一般是针对比较长的字符串 从右往左 从-1 开始)
下面是在 Python 中的操作:
字符串为:0123456798
data:image/s3,"s3://crabby-images/824c2/824c2fbb7bd18e7b81fa945eff909ff1e6626a40" alt=""
?(注:要求是2-5?位置 所以结束位置应该就是在6)
data:image/s3,"s3://crabby-images/d394b/d394bf3115e86d75ad354cb6f5ed7d5a5d9bba06" alt=""
?
data:image/s3,"s3://crabby-images/04466/04466f56d17947053ccf43990a9c64074f04d224" alt=""
?
data:image/s3,"s3://crabby-images/822f3/822f3e181d1cab3d1e34ad4a2b5459b29cee1040" alt=""
?
data:image/s3,"s3://crabby-images/2a070/2a07035e27ea80acaedbf166bac0fee0b5d1b05e" alt=""
?
data:image/s3,"s3://crabby-images/4dfdb/4dfdb3713e5237927495746cb8942888431ceaaf" alt=""
?
data:image/s3,"s3://crabby-images/445e8/445e8ca685479ea690a6dd9dcb221385c16705dd" alt=""
?
data:image/s3,"s3://crabby-images/9fd77/9fd774b93f97ab67f0755b9d973ea993c09fb190" alt=""
?
data:image/s3,"s3://crabby-images/54775/547753f1359d76f9b0fed1daef9a121831ce612f" alt=""
?
data:image/s3,"s3://crabby-images/d685d/d685d89a40b40510517b36c617c5c8cb35fbdc65" alt=""
?
总结
今天学习的 字符串 用法比较多,但是也不需要死记硬背,归类了几个大类,每一个大类里面都分的很清楚的。平时用的时候 pycharm 里面 点字符串用法 再按ctrl + Q 是可以看见提示的
|