Python字符串前加f、r、b、u的不同用法

枫铃3年前 (2021-10-29)Python244

一、字符串前加"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

相关文章

利用python同步windows和linux文件

写python脚本的初衷,每次在windows编辑完文件后,想同步到linux上去,只能够登录服务器,...

爬虫基本原理

爬虫基本原理 一、爬虫是什么? 百度百科和维基百科对网络爬虫的定义:简单来说爬虫就是抓取目标网站内容的工具,一般是根据定义的行...

Django 函数和方法的区别

函数和方法的区别 1、函数要手动传self,方法不用传 2、如果是一个函数,用类名去调用,如果是一个方法...

Django 知识补漏单例模式

单例模式:(说白了就是)创建一个类的实例。在 Python 中,我们可以用多种方法来实现单例模式&#x...

Django基础知识MTV

Django简介 Django是使用Python编写的一个开源Web框架。可以用它来快速搭建一个高性能的网站。 Django也是一个MVC框架。但是在Dj...

Python mysql 索引原理与慢查询优化

一 介绍 为何要有索引? 一般的应用系统,读写比例在10:1左右,而且插入操作和一般的更新操作很少出现性能问题,...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。