ホームページ >バックエンド開発 >Python チュートリアル >Python が文字列表現で二重バックスラッシュを表示するのはなぜですか?
Python 文字列におけるバックスラッシュの二重表現
Python 文字列内でバックスラッシュ () のシーケンスに遭遇すると、重複効果が観察されるのが一般的です。 。この動作は、Python が内部的に文字列を表現する方法に起因します。
表現と実際のコンテンツ
文字列を変数 (例: my_string) に代入すると、変数は次のようになります。その文字列の内部表現。この表現は __repr__() メソッドを使用して作成されます。ただし、文字列を出力すると (例: print(my_string))、文字列の実際の内容が重複したバックスラッシュなしで表示されます。
たとえば、次の文字列を考えてみましょう。
my_string = "why\does\it\happen?"
repr() メソッドは、この文字列を次のように変換します。
'why\does\it\happen?'
表現内の二重バックスラッシュに注意してください。ただし、my_string を出力すると、次のメッセージが表示されます:
why\does\it\happen?
Why the Duplication?
Python はエスケープ文字としてバックスラッシュを使用します。たとえば、n は改行を表し、t はタブを表します。意図したエスケープ シーケンスとリテラルのバックスラッシュを区別するために、Python は文字列表現で使用されているバックスラッシュを別のバックスラッシュでエスケープします。
混乱を解決する
実際のバックスラッシュを取得するには単一のバックスラッシュを含む文字列の内容には、print() 関数を使用します。文字列の表現が必要な場合は、 repr() 組み込み関数を使用してアクセスできます。
print(my_string) # why\does\it\happen? print(repr(my_string)) # 'why\does\it\happen?'
バックスラッシュのエスケープ
文字列内のリテラルのバックスラッシュの場合は、別のバックスラッシュでエスケープする必要があります。これにより、Python がバックスラッシュをエスケープ文字として解釈するのを防ぎます。例:
"this\text\is\what\you\need" # Produces: this\text\is\what\you\need
以上がPython が文字列表現で二重バックスラッシュを表示するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。