Python 3 で文字列をバイトに変換する最良の方法: 説明
Python 3 は、実行しようとすると TypeError を発生させます。文字列がバッファ インターフェイスをサポートしていないため、文字列をバイトに直接変換します。このエラー メッセージは、「次のメソッドのどれがより Python 的ですか?
b = bytes(mystring, 'utf-8') b = mystring.encode('utf-8')
バイト コンストラクターの探索
バイトに関するドキュメントを調べると、 bytearray を指します。これは、バイト配列を初期化するためのさまざまなオプションを提供します。これらのオプションの中で、
bytearray(source[, encoding[, errors]])
ここで、source が文字列の場合、encoding および errors パラメーターは次のとおりです。 bytearray() は、以下を使用して文字列をバイトに変換します。 str.encode().
Python の考慮事項
bytes は文字列エンコードを超える広範な機能を提供しますが、文字列をエンコードするという特定のタスクでは、some_string.encode(encoding) はより Python 的であると考えられます。これは主に、「この文字列を取得し、このエンコーディングでエンコードする」という意図を明示的に示しているため、その明確さと目的のためです。
対照的に、bytes(some_string, encoding)明示的な動詞が欠けているため、意図した操作がわかりにくくなります。
パフォーマンスと実装
Python ソース コードの分析により、unicode_string.encode(encoding) が内部で PyUnicode_AsEncodedString を呼び出していることが確認されます。これはバイトで使用されるものと同じ実装です。 () コンストラクター。したがって、文字列エンコードの 2 つの方法の間にパフォーマンスや効率の違いはありません。
対称性と可読性
さらに、unicode_string.encode(encoding) その逆と対称にペアになります。 byte_string.decode(encoding) は、文字列表現とバイト表現の間で変換するための一貫した直感的なアプローチを提供します。
したがって、mystring.encode('utf-8) と結論付けられます。 ') は、Python 3 で文字列をバイトに変換するための、より Python 的で推奨される方法です。
以上がPython 3 で文字列をバイトに変換するより Python 的な方法は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。