python创建元组时在字符串前面加b_字符串前面加 u,r ,b//urlparse的用法。

f.write(self.receive_data.split(b'\r\n\r\n')[1])

导语:

今天在学习的时候遇到了这样一句话,一个字符串前面加了个字母,那么它有什么含义呢,有什么作用呢,其实它也没什么作用,表示bytes,只是为了兼容python3.x的写法。

下面的是字符串前面加常用字母的意义:

字符串前面加u、r、b的含义

u/U:表示unicode字符串

不是仅仅是针对中文, 可以针对任何的字符串,代表是对字符串进行unicode编码。 一般英文字符在使用各种编码下, 基本都可以正常解析, 所以一般不带u;但是中文, 必须表明所需编码, 否则一旦编码转换就会出现乱码。 建议所有编码方式采用utf8

r/R:非转义的原始字符串

与普通字符相比,其他相对特殊的字符,其中可能包含转义字符,即那些,反斜杠加上对应字母,表示对应的特殊含义的,比如最常见的”\n”表示换行,”\t”表示Tab等。而如果是以r开头,那么说明后面的字符,都是普通的字符了,即如果是“\n”那么表示一个反斜杠字符,一个字母n,而不是表示换行了。

注意:以r开头的字符,常用于正则表达式,对应着re模块。

b:bytes

python3.x里默认的str是(py2.x里的)unicode, bytes是(py2.x)的str, b”“前缀代表的就是bytes

python2.x里, b前缀没什么具体意义, 只是为了兼容python3.x的这种写法

还有就是记录一下 urlparse模块

urlparse模块

这个模块是用来处理url的,主要把url拆分为6个部分,返回的是一个元组

元组为(scheme, netloc, path, parameters, query, fragment)

每个组件是一个字符串,有可能是空的,我们常用的path 和 netloc.

注意一下这个模块 在urllib模块里,是直接python里自带的,我安了10分钟发现,安不上,原来是自带的。

下面来测试使用一下:

from urllib.parse import urlparse #该模块可以直接使用,是自带的,如果强行安装是安不上的

url = urlparse('https://dn-simplecloud.shiyanlou.com/ncn1.jpg')

print(url)

结果

ParseResult(scheme='https', netloc='dn-simplecloud.shiyanlou.com', path='/ncn1.jpg', params='', query='', fragment='')

当然这个模块还有很多用法,这里只是介绍了一小部分,今天的总结就这样了。如果有任何错误,欢迎指正。

原文链接:https://blog.csdn.net/weixin_45290352/article/details/106407828

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值