Python3 字符串
是最常用的数据类型,用单引号或双引号括起来创建字符串
一般创建变量给变量赋值时创建字符串
Python 访问字符串中的值
实际上就是字符串的截取
需要注意的是,Python中没有一种数据类型叫单字符,如果字符串只有一个字符那也叫字符串,可进行的操作和字符串相同
截取字符串的方法是[,]中括号
#!/usr/bin/python3
var1 = 'Hello World!'
var2 = "Runoob"
print ("var1[0]: ", var1[0])
print ("var2[1:5]: ", var2[1:5])
输出结果为
var1[0]: H
var2[1:5]: unoo
Python 字符串更新
实际上就是字符串的拼接或者截取字符串后再拼接,做到产生新字符串的效果
但是已经建立的字符串是不能更改的,只有拼接和截取手段
#!/usr/bin/python3
var1 = 'Hello World!'
print ("已更新字符串 : ", var1[:6] + 'Runoob!')
输出结果为
已更新字符串 : Hello Runoob!
Python转义字符
这应该是通过转义字符使字符串有着特殊意义
转义字符都含有反斜杠/
(在行尾时) 续行符
\ 反斜杠符号
’ 单引号
" 双引号
\a 响铃
\b 退格(Backspace)
\000 空
\n 换行
\v 纵向制表符
\t 横向制表符
\r 回车
\f 换页
\oyy 八进制数,yy 代表的字符,例如:\o12 代表换行,其中 o 是字母,不是数字 0。
\xyy 十六进制数,yy代表的字符,例如:\x0a代表换行
\other 其它的字符以普通格式输出
Python字符串运算符
字符串也有运算,和昨天运算符中讲的一样,字符串的运算一般有拼接、判断(成员运算符)、截取
+字符串连接
*重复输出字符串
[] 通过索引获取字符串中字符
[ : ] 截取字符串中的一部分,遵循左闭右开原则,str[0:2] 是不包含第 3 个字符的。
in 成员运算符 - 如果字符串中包含给定的字符返回 True
not in 成员运算符 - 如果字符串中不包含给定的字符返回 True
r/R
原始字符串 - 原始字符串:所有的字符串都是直接按照字面的意思来使用,没有转义特殊或不能打印的字符。 原始字符串除在字符串的第一个引号前加上字母 r(可以大小写)以外,与普通字符串有着几乎完全相同的语法。
% 格式字符串
#!/usr/bin/python3
a = "Hello"
b = "Python"
print("a + b 输出结果:", a + b)
print("a * 2 输出结果:", a * 2)
print("a[1] 输出结果:", a[1])
print("a[1:4] 输出结果:", a[1:4])
if( "H" in a) :
print("H 在变量 a 中")
else :
print("H 不在变量 a 中")
if( "M" not in a) :
print("M 不在变量 a 中")
else :
print("M 在变量 a 中")
print (r'\n')
print (R'\n')
输出结果为
a + b 输出结果: HelloPython
a * 2 输出结果: HelloHello
a[1] 输出结果: e
a[1:4] 输出结果: ell
H 在变量 a 中
M 不在变量 a 中
\n
\n
Python字符串格式化
原话是Python 支持格式化字符串的输出 。尽管这样可能会用到非常复杂的表达式,但最基本的用法是将一个值插入到一个有字符串格式符 %s 的字符串中。
我理解的是像是一道填空题,可以后续输入插入到原本的字符串中间,有点像英语的完形填空,将一个数字或字符串之类的不全一句话,插入不同的数据类型有不同的格式化符
这好像只是其中一个作用还有其他作用不是很理解
#!/usr/bin/python3
print ("我叫 %s 今年 %d 岁!" % ('小明', 10))
输出结果为
我叫 小明 今年 10 岁!
%c 格式化字符及其ASCII码
%s 格式化字符串
%d 格式化整数
%u 格式化无符号整型
%o 格式化无符号八进制数
%x 格式化无符号十六进制数
%X 格式化无符号十六进制数(大写)
%f 格式化浮点数字,可指定小数点后的精度
%e 用科学计数法格式化浮点数
%E 作用同%e,用科学计数法格式化浮点数
%g %f和%e的简写
%G %f 和 %E 的简写
%p 用十六进制数格式化变量的地址
格式化操作符辅助指令:
- 定义宽度或者小数点精度
- 用做左对齐
- 在正数前面显示加号( + )
在正数前面显示空格
#在八进制数前面显示零(‘0’),在十六进制前面显示’0x’或者’0X’(取决于用的是’x’还是’X’)
0 显示的数字前面填充’0’而不是默认的空格
% ‘%%‘输出一个单一的’%’
(var) 映射变量(字典参数)
m.n. m 是显示的最小总宽度,n 是小数点后的位数(如果可用的话)
Python2.6 开始,新增了一种格式化字符串的函数 str.format(),它增强了字符串格式化的功能。
Python三引号
三引号的作用是实现在给变量赋值的时候输入多行字符串
字符串中可以包含换行符、制表符以及其他特殊字符。
#!/usr/bin/python3
para_str = """这是一个多行字符串的实例
多行字符串可以使用制表符
TAB ( \t )。
也可以使用换行符 [ \n ]。
"""
print (para_str)
输出结果为
这是一个多行字符串的实例
多行字符串可以使用制表符
TAB ( )。
也可以使用换行符 [
]。
f-string
f-string 是 python3.6 之后版本添加的,称之为字面量格式化字符串,是新的格式化字符串的语法。
之前我们习惯用百分号 (%):
name = ‘Runoob’
‘Hello %s’ % name
‘Hello Runoob’
f-string 格式化字符串以 f 开头,后面跟着字符串,字符串中的表达式用大括号 {} 包起来,它会将变量或表达式计算后的值替换进去,实例如下:
name = ‘Runoob’
f’Hello {name}’ # 替换变量
f’{1+2}’ # 使用表达式
‘3’
w = {‘name’: ‘Runoob’, ‘url’: ‘www.runoob.com’}
f’{w[“name”]}: {w[“url”]}’
‘Runoob: www.runoob.com’
用了这种方式明显更简单了,不用再去判断使用 %s,还是 %d。
在 Python 3.8 的版本中可以使用 = 符号来拼接运算表达式与结果:
x = 1
print(f’{x+1}’) # Python 3.6
2
Unicode 字符串
在Python2中,普通字符串是以8位ASCII码进行存储的,而Unicode字符串则存储为16位unicode字符串,这样能够表示更多的字符集。使用的语法是在字符串前面加上前缀 u。
在Python3中,所有的字符串都是Unicode字符串。