binascii
— Convert between binary and ASCII¶
The binascii
module contains a number of methods to convert between
binary and various ASCII-encoded binary representations. Normally, you will not
use these functions directly but use wrapper modules like uu
,
base64
, or binhex
instead. The binascii
module contains
low-level functions written in C for greater speed that are used by the
higher-level modules.
참고
a2b_*
함수는 ASCII 문자만 포함하는 유니코드 문자열을 받아들입니다. 다른 함수는 바이트열류 객체(가령 bytes
, bytearray
및 버퍼 프로토콜을 지원하는 다른 객체)만 받아들입니다.
버전 3.3에서 변경: ASCII로만 이루어진 유니코드 문자열은 이제 a2b_*
함수에서 허용됩니다.
binascii
모듈은 다음 함수를 정의합니다:
-
binascii.
a2b_uu
(string)¶ 한 줄의 UU 인코딩된 데이터 string을 바이너리로 역변환하고 바이너리 데이터를 반환합니다. 마지막 줄을 제외하고는, 줄은 보통 45 (바이너리) 바이트를 포함합니다. 줄 데이터 뒤에는 공백 문자가 올 수 있습니다.
-
binascii.
b2a_uu
(data, *, backtick=False)¶ 바이너리 data를 ASCII 문자의 줄로 변환합니다, 반환 값은 개행 문자를 포함하는 변환 된 줄입니다. data의 길이는 최대 45이어야 합니다. backtick가 참이면, 0은 스페이스 대신
'`'
으로 표현됩니다.버전 3.7에서 변경: backtick 매개 변수가 추가되었습니다.
-
binascii.
a2b_base64
(string)¶ base64 데이터 블록을 바이너리로 역변환하고 바이너리 데이터를 반환합니다. 한 번에 한 줄 이상을 전달할 수 있습니다.
-
binascii.
b2a_base64
(data, *, newline=True)¶ 바이너리 data를 base64 코딩으로 ASCII 문자의 줄로 변환합니다. 반환 값은 변환된 줄인데, newline이 참이면, 개행 문자를 포함합니다. 이 함수의 출력은 RFC 3548을 따릅니다.
버전 3.6에서 변경: newline 매개 변수가 추가되었습니다.
-
binascii.
a2b_qp
(data, header=False)¶ quoted-printable data 블록을 바이너리로 역변환하고 바이너리 데이터를 반환합니다. 한 번에 한 줄 이상을 전달할 수 있습니다. 선택적 인자 header가 있고 참이면, 밑줄(underscore)은 스페이스로 디코딩됩니다.
-
binascii.
b2a_qp
(data, quotetabs=False, istext=True, header=False)¶ 바이너리 data를 quoted-printable 인코딩으로 ASCII 문자의 줄로 변환합니다. 반환 값은 변환된 줄입니다. 선택적 인자 quotetabs가 있고 참이면, 모든 탭과 스페이스가 인코딩됩니다. 선택적 인자 istext가 있고 참이면, 개행 문자는 인코딩되지 않지만, 후행 공백은 인코딩됩니다. 선택적 인자 header가 있고 참이면, 스페이스는 RFC 1522에 따라 밑줄로 인코딩됩니다. 선택적 인자 header가 있고 거짓이면, 개행 문자도 함께 인코딩됩니다; 그렇지 않으면 라인 피드(linefeed) 변환이 바이너리 데이터 스트림을 손상할 수 있습니다.
-
binascii.
a2b_hqx
(string)¶ Convert binhex4 formatted ASCII data to binary, without doing RLE-decompression. The string should contain a complete number of binary bytes, or (in case of the last portion of the binhex4 data) have the remaining bits zero.
버전 3.9부터 폐지.
-
binascii.
rledecode_hqx
(data)¶ Perform RLE-decompression on the data, as per the binhex4 standard. The algorithm uses
0x90
after a byte as a repeat indicator, followed by a count. A count of0
specifies a byte value of0x90
. The routine returns the decompressed data, unless data input data ends in an orphaned repeat indicator, in which case theIncomplete
exception is raised.버전 3.2에서 변경: Accept only bytestring or bytearray objects as input.
버전 3.9부터 폐지.
-
binascii.
rlecode_hqx
(data)¶ Perform binhex4 style RLE-compression on data and return the result.
버전 3.9부터 폐지.
-
binascii.
b2a_hqx
(data)¶ Perform hexbin4 binary-to-ASCII translation and return the resulting string. The argument should already be RLE-coded, and have a length divisible by 3 (except possibly the last fragment).
버전 3.9부터 폐지.
-
binascii.
crc_hqx
(data, value)¶ 초기 CRC value로 시작하는, data의 16비트 CRC 값을 계산하고 결과를 반환합니다. 종종 0x1021로 표시되는, CRC-CCITT 다항식 x16 + x12 + x5 + 1을 사용합니다. 이 CRC는 binhex4 형식에서 사용됩니다.
-
binascii.
crc32
(data[, value])¶ 초기 CRC value로 시작하는, data의 부호 없는 32비트 체크섬인 CRC-32를 계산합니다. 기본 초기 CRC는 0입니다. 이 알고리즘은 ZIP 파일 체크섬과 일치합니다. 이 알고리즘은 체크섬 알고리즘으로 사용하도록 설계되었으므로, 일반 해시 알고리즘으로 사용하기에 적합하지 않습니다. 다음과 같이 사용하십시오:
print(binascii.crc32(b"hello world")) # Or, in two pieces: crc = binascii.crc32(b"hello") crc = binascii.crc32(b" world", crc) print('crc32 = {:#010x}'.format(crc))
버전 3.0에서 변경: The result is always unsigned. To generate the same numeric value when using Python 2 or earlier, use
crc32(data) & 0xffffffff
.
-
binascii.
b2a_hex
(data[, sep[, bytes_per_sep=1]])¶ -
binascii.
hexlify
(data[, sep[, bytes_per_sep=1]])¶ 바이너리 data의 16진수 표현을 반환합니다. data의 모든 바이트는 해당 2자리 16진수 표현으로 변환됩니다. 따라서 반환된 바이트열 객체의 길이는 data 의 두 배입니다.
비슷한 기능(하지만 텍스트 문자열을 반환하는)을
bytes.hex()
메서드를 사용하여 편리하게 액세스할 수도 있습니다.sep이 지정되면, 단일 문자 문자열이나 바이트열 객체여야 합니다. bytes_per_sep 입력 바이트마다 출력에 삽입됩니다. 구분자 배치는 기본적으로 출력의 오른쪽 끝에서부터 계산됩니다. 왼쪽부터 계산하려면, 음수의 bytes_per_sep 값을 제공하십시오.
>>> import binascii >>> binascii.b2a_hex(b'\xb9\x01\xef') b'b901ef' >>> binascii.hexlify(b'\xb9\x01\xef', '-') b'b9-01-ef' >>> binascii.b2a_hex(b'\xb9\x01\xef', b'_', 2) b'b9_01ef' >>> binascii.b2a_hex(b'\xb9\x01\xef', b' ', -2) b'b901 ef'
버전 3.8에서 변경: sep과 bytes_per_sep 매개 변수가 추가되었습니다.
-
binascii.
a2b_hex
(hexstr)¶ -
binascii.
unhexlify
(hexstr)¶ 16진수 문자열 hexstr로 표현된 바이너리 데이터를 반환합니다. 이 함수는
b2a_hex()
의 역함수입니다. hexstr는 짝수개의 16진수(대소문자 모두 가능합니다)를 포함해야 하며, 그렇지 않으면Error
예외가 발생합니다.비슷한 기능(텍스트 문자열 인자만 받아들이지만, 공백에 대해 더 느슨한)을
bytes.fromhex()
클래스 메서드를 사용하여 액세스할 수도 있습니다.
-
exception
binascii.
Error
¶ 에러 시 발생하는 예외. 이들은 대개 프로그래밍 에러입니다.
-
exception
binascii.
Incomplete
¶ 불완전한 데이터에서 발생하는 예외. 이들은 일반적으로 프로그래밍 에러가 아니지만, 조금 더 많은 데이터를 읽고 다시 시도하면 처리될 수 있습니다.