Python字符串前加f、r、b、u的不同用法
一、字符串前加"f"
1. %
可以使用 % 格式化字符串。
c = (250, 250)
# 使用 % 格式化
s1 = "坐标为:%s" % c
# TypeError: not all arguments converted during string formatting
s1 = "坐标为:%s" % (c,) # '坐标为:(250, 250)'
# 使用 format 格式化
s2 = "坐标为:{}".format(c) # '坐标为:(250, 250)'
2.format
Python 2.6 引入 format 格式化字符串的方式。
str.format() 是对 %-formatting 的改进,替换字段使用大括号 {} 标记。
"Hello, {}. You are {}.".format(name, age)
可以通过引用索引来改变引入顺序:
'''
学习中遇到问题没人解答?小编创建了一个Python学习交流QQ群:531509025
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
age = 100
name = 'Hider'
print("Hello {1}.You are {0}-{0}.".format(age, name))
# 'Hello Hider.You are 100-100.'
如果插入变量名称,则会获得额外传递对象的权限:
person = {'name':'Hider', 'age':100}
print("Hello {name}.You are {age}.".format(age=person['age'], name=person['name']))
# 'Hello Hider.You are 100.'
使用 *
可以针对列表进行解码:
data = ["Hider", 100]
print("Name:{0}, Age:{1}.".format(*data))
# 'Name:Hider, Age:100.'
使用 ** 来使用字典完成巧妙技巧:
person = {'name':'Hider', 'age':100}
print("Hello {name}.You are {age}.".format(**person)) # 解开字典形成独立形参
# 'Hello Hider.You are 100.'
填充与对齐
^、<、>
分别是居中、左对齐、右对齐,后面带宽度参数。
:
后面带填充的字符,只能是一个字符,默认空格填充。
'''
学习中遇到问题没人解答?小编创建了一个Python学习交流QQ群:531509025
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
print("{:>10}".format('18'))# ' 18'
print("{:0>10}".format('18')) # '0000000018'
print("{:A>10}".format('18')) # 'AAAAAAAA18'
print("{:A^10}".format('18')) # 'AAAA18AAAA'
zfill 方法补充
zfill方法返回指定长度的字符串,原字符串右对齐,前面填充0,使用语法为:
str.zfill(width)
print("18".zfill(10)) # '0000000018'
精度与类型f
精度常跟类型f一起使用:
print("{:.2f}".format(3.1415926)) # '3.14'
# 小数点后2位 float类型
其他进制
b、d、o、x分别代表二进制、十进制、八进制、十六进制。
'''
学习中遇到问题没人解答?小编创建了一个Python学习交流QQ群:531509025
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
print("{:b}".format(18)) # '10010'
print("{:d}".format(18)) # '18'
print("{:o}".format(18)) # '22'
print("{:x}".format(18)) # '12'
千位分隔符
print("{:,}".format(1234567890)) # '1,234,567,890'
str.format( )是一个升级版本,代码易读,但当处理多个参数和更长字符串时,非常冗长,每个变量都要指明。
使用字典的方式 .format(**dict)
解压,并通过字符串中的键值引用。
3.Python 3.6 之 f’{}’ —— 一种改进Python格式字符串的新方法
格式化字符串常量(formatted string literals)是 Python 3.6 新引入的一种字符串格式化方法,主要目的是使格式化字符串的操作更加简便。
-
f-string在形式上是以 f 或者 F 修饰符引领的字符串(f’xxx’ 或 F’xxx’),以大括号 {} 标明被替代的字段。
-
f-string本质上不是字符串产常量,而是一个在运行时运算求值的表达式。
# 创建
my_dict = {'name':'Hider',
'age':'100'}
print(f"My name is {my_dict['name']}, I'm {my_dict['age']}.")
# My name is Hider, I'm 100.
import time
t0 = time.time()
time.sleep(1)
name = 'processing'
# f支持在字符串内使用大括号{}的python表达式
print(f"{name} done in {time.time() - t0:.2f} s.")
# processing done in 1.00 s.
二、字符串前加"r"
r
的作用是去除转义字符。
例如:\n
表示反斜杠字符+
字母n
,而不是换行符。
以r
开头的字符,常用于正则表达式,对应re
模块。
'''
学习中遇到问题没人解答?小编创建了一个Python学习交流QQ群:531509025
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
str1 = 'input\n'
str2 = r'input\n'
print(str1) # input 并换行
print(str2) # input\n
三、字符串前加"b"
b
的作用是表示一个 bytes 对象。
网络编程中,服务器和浏览器只认 bytes 类型数据。
例如:
response = b'<h1>Hello World!</h1>'
send 函数的参数和 recv 函数返回值都是 bytes 类型。
在 Python3 中,bytes 和 str 相互转换方式:
str.encode('utf-8') # 编码
bytes.decode('utf-8') # 解码
四、字符串前加"u"
u
的作用是表示字符串以 Unicode 格式进行编码。
一般用在中文字符串前面,防止因为源码储存格式问题,导致再次使用时出现乱码。
例如:
u'我是中文字符串。'
结尾给大家推荐一个非常好的学习教程,希望对你学习Python有帮助!
Python基础入门教程推荐:更多Python视频教程-关注B站:Python学习者
https://www.bilibili.com/video/BV1LL4y1h7ny?share_source=copy_web
Python爬虫案例教程推荐:更多Python视频教程-关注B站:Python学习者
https://www.bilibili.com/video/BV1QZ4y1N7YA?share_source=copy_web