从TypeError的答案中可以看出,有两种不同的方式可以将字符串转换为字节:’str’不支持缓冲区接口
以下哪种方法更好或更Pythonic?还是仅仅是个人喜好问题?
b = bytes(mystring, 'utf-8')
b = mystring.encode('utf-8')
如果你查看的文档bytes
,它将指向bytearray
:
bytearray
([源[
,编码[
,错误]]]
)
返回一个新的字节数组。bytearray
类型是一个可变的整数序列,范围为0 <= x <256
。它具有可变序列类型中介绍的大多数可变序列的常用方法,以及字节类型具有的大多数方法,请参见Bytes和字节数组方法。
可选的source
参数可以通过几种不同的方式用于初始化数组:
如果是字符串,则还必须提供编码(以及可选的错误)参数;然后,bytearray()
使用str.encode()
将字符串转换为字节。
如果它是整数,则数组将具有该大小,并将使用空字节初始化。
如果它是符合缓冲区接口的对象,则该对象的只读缓冲区将用于初始化bytes
数组。
如果是可迭代的,则它必须是0 <= x <256
范围内的整数的可迭代对象,这些整数用作数组的初始内容。
没有参数,将创建大小为0的数组。
因此,bytes
除了编码字符串以外,还可以做更多的事情。这是Pythonic
的用法,它允许你使用有意义的任何类型的源参数来调用构造函数。
对于字符串编码,我认为它some_string.encode(encoding)
比使用构造函数更具有Pythonic
风格,因为它是最易于记录的文档-“使用此字符串并以这种编码方式对其进行编码”比bytes(some_string, encoding)
- 更加清晰明了-当你使用构造函数。
编辑:我检查了Python源。如果将unicode字符串传递给bytes使用CPython,它将调用PyUnicode_AsEncodedString
,它是encode; 的实现。因此,如果你自称,则只是跳过了一个间接级别encode。
另外,请参见Serdalis
的评论- unicode_string.encode(encoding)
也是Python 风格的,因为它的反函数是byte_string.decode(encoding)
,对称性很好。
本文向大家介绍在Python3中将字符串转换为字节的最佳方法,包括了在Python3中将字符串转换为字节的最佳方法的使用技巧和注意事项,需要的朋友参考一下 要将字符串转换为字节,有多种方法, 方法1:使用encode()方法 输出结果 在python3中,第一个参数encode()默认为'utf-8'。据推测,这种方法也更快,因为默认参数在C代码中导致NULL。 方法2:使用bytes()构造函数
问题内容: 我有一个我想完全输出为String的。本质上,我想使用由制表符分隔的每个元素按顺序输出。有什么快速的方法可以做到这一点吗?你可以遍历它(或删除每个元素)并将其连接为字符串,但我认为这会非常慢。 问题答案: 基本上,使用循环来迭代是唯一的选择: 不要使用此代码,请继续阅读此答案的底部,以了解为什么不希望使用此代码,以及应该使用哪个代码代替: 实际上,字符串串联就可以了,因为javac编译
我试图想出一个好的解决方案来将字符串转换为json格式,但我不知道它是否足够好。 我想我可能会使用str.replace from(to{,并在}{之间插入逗号,但我如何找到要插入的索引?“”代表Name、Author、fileSize呢?在转换为可读的json字符串之后,我可以序列化为json(由GSON/Jackson)。
问题内容: 将数字转换为字符串的“最佳”方法是什么(就速度优势,清晰度优势,内存优势等而言)? 一些例子: 问题答案: 像这样: 实际上,即使我通常是为了简单方便而这样做,但 对于原始速度而言 ,似乎出现了1000多次迭代,但 对于 根据上述JSPerf测试最快: 应该注意的是,当您认为速度差异可以在0.1秒内进行1百万次转换时,速度差异并不是太大。 更新: 速度因浏览器而异。在Chrome中,根
问题内容: 我想在GO中将字符串数组转换为字节数组,以便可以将其写到磁盘上。将字符串数组()解码为字节数组()的最佳解决方案是什么? 我正在考虑对字符串数组进行两次迭代,第一个迭代以获得字节数组所需的实际大小,然后第二个迭代写入每个元素的长度和实际字符串()。 解决方案必须能够以其他方式进行转换;从一个到一个。 问题答案: 让我们忽略一个事实,那就是走一秒钟。您需要做的第一件事是将序列化格式编组为
问题内容: 我是Go的新手,正在尝试执行以下操作: 我搜索了很多,但真的不知道该怎么做。 我知道这行不通: 问题答案: 这不是实现它的最有效方法,但是您可以简单地编写: 被称为: