1.字符串前加 u:后面字符串以 unicode 格式进行编码(表示中文),一般用在中文字符串前面,防止因为源码储存格式问题,导致再次使用时出现乱码。
【不是仅仅是针对中文, 可以针对任何的字符串,代表是对字符串进行unicode编码。一般英文字符在使用各种编码下, 基本都可以正常解析, 所以一般不带u;但是中文, 必须表明所需编码, 否则一旦编码转换就会出现乱码。 建议所有编码方式采用utf8】
使用场景:一般用在中文字符串前面,防止因为源码储存格式问题,导致再次使用时出现乱码。
2.字符串前加 r:在字符串前加r可防止字符串转义
r"" 的作用是:去除转义字符
①字符串常量,在字符串前加r
场景:想复制某个文件夹的目录,假设是 F:\Python_Easy\n4\test.py
当不用 r"" ,有三种写法:
print("F:\Python_Easy\n4\test.py ")print("F:\\Python_Easy\\n4\\test.py ")
print("F:/Python_Easy/n4/test.py ")
运行结果:
F:\Python_Easy4 est.py
F:\Python_Easy\n4\test.py
F:/Python_Easy/n4/test.py
而通常如果直接复制目录路径的话,你就粘贴出来的字符串就是第一行代码所示,所有 \ 会当成转义符;而为了消除转义作用,需要手动再加一个 \ ,否则你也得手动改成何第三行代码一样。
而 r"" 的出现就是为了避免这种情况。
②如果字符串是从文件中读取,则在读取时加r
例如:有文件 test.txt中有 adfdfasd\tfdsadf\t E:\codes则代码可以这么写:
file1=open(r"text.txt","r")
for line in file1:
print(line)
结果为:
adfdfasd\tfdsadf\t E:\codes
3.字符串前加 b:b" "前缀表示:后面字符串是bytes类型【 b' ' 表示后面的字符串是bytes 对象】。
网络编程中,服务器和浏览器只认bytes 类型数据。
在 Python3 中,bytes 和 str 的互相转换方式:
str--->bytes:【str.encode('utf-8')】bytes--->str:【bytes.decode('utf-8')】
举例:
print("中文".encode(encoding="utf-8"))print(b'\xe4\xb8\xad\xe6\x96\x87'.decode())
print(r'\xe4\xb8\xad\xe6\x96\x87')
运行结果:
b'\xe4\xb8\xad\xe6\x96\x87'中文
\xe4\xb8\xad\xe6\x96\x87
可以看到,当你不加 b"" 时,他也就是个普通的字符串而已,不会识别为字节类型。
bytes数据类型应用场景:像图片、音视频等文件的读写就是用bytes数据。
4.字符串前加 f:以f开头表示在字符串内支持大括号内的python 表达式
作用:相当于 format 函数。
例如:
name = "帅哥"age = 12
print(f"my name is {name},age is {age}")
运行结果:
my name is 帅哥,age is 12
转义字符
描述
\(在行尾时)
续行符
\\
反斜杠符号
\'
单引号
\"
双引号
\a
响铃
\b
退格(Backspace)
\e
转义
\000
空
\n
换行
\v
纵向制表符
\t
横向制表符
\r
回车
\f
换页
\oyy
八进制数yy代表的字符,例如:\o12代表换行
\xyy
十进制数yy代表的字符,例如:\x0a代表换行
\other
其它的字符以普通格式输出
去期待陌生,去拥抱惊喜。