항상 나를 괴롭히는 것처럼 보이기 때문에 나중에 검색 할 수 있도록 이것을 게시하십시오.
$ python3.2
Python 3.2 (r32:88445, Oct 20 2012, 14:09:50)
[GCC 4.5.2] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import curses
>>> print(curses.version)
b'2.2'
>>> print(str(curses.version))
b'2.2'
>>> print(curses.version.encode('utf-8'))
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
AttributeError: 'bytes' object has no attribute 'encode'
>>> print(str(curses.version).encode('utf-8'))
b"b'2.2'"
질문 : bytes
파이썬 3에서 b'
접두사 없이 바이너리 ( ) 문자열 을 인쇄하는 방법은 무엇입니까?
답변
사용 decode
:
print(curses.version.decode())
# 2.2
답변
바이트가 이미 적절한 문자 인코딩을 사용하는 경우; 직접 인쇄 할 수 있습니다.
sys.stdout.buffer.write(data)
또는
nwritten = os.write(sys.stdout.fileno(), data) # NOTE: it may write less than len(data) bytes
답변
의 소스를 살펴보면 이 메서드에 구워진 bytes.__repr__
것처럼 보입니다 b''
.
가장 확실한 해결 방법은 b''
결과 에서을 수동으로 분리하는 것 입니다 repr()
.
>>> x = b'\x01\x02\x03\x04'
>>> print(repr(x))
b'\x01\x02\x03\x04'
>>> print(repr(x)[2:-1])
\x01\x02\x03\x04
답변
데이터가 UTF-8 호환 형식이면 바이트를 문자열로 변환 할 수 있습니다.
>>> import curses
>>> print(str(curses.version, "utf-8"))
2.2
데이터가 아직 UTF-8과 호환되지 않는 경우 선택적으로 먼저 16 진수로 변환합니다. 예를 들어 데이터가 실제 원시 바이트 인 경우.
from binascii import hexlify
from codecs import encode # alternative
>>> print(hexlify(b"\x13\x37"))
b'1337'
>>> print(str(hexlify(b"\x13\x37"), "utf-8"))
1337
>>>> print(str(encode(b"\x13\x37", "hex"), "utf-8"))
1337