>백엔드 개발 >파이썬 튜토리얼 >Python에서 struct.pack() 및 struct.unpack() 사용법에 대한 자세한 설명

Python에서 struct.pack() 및 struct.unpack() 사용법에 대한 자세한 설명

高洛峰
高洛峰원래의
2017-03-16 16:02:0113598검색

python의 구조체는 주로 C 구조 데이터를 처리하는 데 사용됩니다. 읽을 때 먼저 Python의 string 유형으로 변환된 다음 Python의 구조화된 유형으로 변환됩니다. 튜플 같은 거요~. 일반적으로 입력 채널은 파일 또는 네트워크 바이너리 스트림에서 제공됩니다.

1.struct.pack() 및 struct.unpack()

변환 프로세스 중에 형식 문자열(for mat strings), 변환 방법과 형식을 지정하는 데 사용됩니다.

주요 메서드에 대해 이야기해 보겠습니다.

1.1 struct.pack(fmt,v1,v2,...)

v1, v2 및 기타 매개변수를 입력합니다. 값은 다음과 같습니다. 하나의 레이어로 래핑되며 래핑 방법은 fmt에 의해 지정됩니다. 래핑된 매개변수는 fmt를 엄격하게 준수해야 합니다. 마지막으로 래핑된 문자열이 반환됩니다.

1.2 struct.unpack(fmt,string)

이름에서 알 수 있듯이 압축을 풉니다. 예를 들어 pack은 packaged이고 unpacked는 unpack에 사용될 수 있습니다. 데이터(문자열)를 언팩하여 얻은 튜플을 반환하며, 데이터가 하나만 있어도 튜플로 언팩됩니다. 그중 len(string)은 calcsize함수를 포함하는 calcsize(fmt)와 동일해야 합니다. struct.calcsize(fmt): fmt 형식에 설명된 구조의 크기를 계산하는 데 사용됩니다.

형식 문자열은 하나 이상의 형식 문자로 구성됩니다. 이러한 형식 문자에 대한 설명은 다음과 같이 Python 설명서를 참조하세요.

Python에서 struct.pack() 및 struct.unpack() 사용법에 대한 자세한 설명

2 . 코드 예

import struct 
# native byteorder 
buffer = struct.pack("ihb", 1, 2, 3) 
print repr(buffer) 
print struct.unpack("ihb", buffer) 
# data from a sequence, network byteorder 
data = [1, 2, 3] 
buffer = struct.pack("!ihb", *data)
print repr(buffer) 
print struct.unpack("!ihb", buffer)
 
Output:
'\x01\x00\x00\x00\x02\x00\x03'
(1, 2, 3)
'\x00\x00\x00\x01\x00\x02\x03'
(1, 2, 3)

첫 번째 팩 매개변수 1,2,3. 패키징 전, 1,2,3은 패키징 후 분명히 Python데이터 유형에서 integer에 속합니다. , C 구조의 바이너리 문자열이 되며, 파이썬 문자열 형식으로 변환하면 'x01x00x00x00x02x00x03'으로 표시됩니다. 이 기계는 리틀엔디안('little-endian')이므로 빅엔디안과 리틀엔디안의 차이점은 여기를 참고하시기 바랍니다. 따라서 높은 비트는 낮은 주소 세그먼트에 배치됩니다. 는 C 구조체에서 int 유형을 나타내므로 이 기계는 4비트를 차지하고 1은 01000000으로 표시됩니다. h는 C 구조체에서 짧은 유형을 나타내며 2비트를 차지하므로 b는 유사하게 표시됩니다. C 구조체의 signed char 타입은 1비트를 차지하므로 03으로 표현됩니다.

다른 구조체의 변환도 비슷하지만, 몇몇 특별한 구조체에 대해서는 공식 문서의 매뉴얼을 참고하세요. .

형식 문자열의 시작 부분에는 빅 엔디안과 리틀 엔디안을 결정하는 선택적 문자가 있으며 목록은 다음과 같습니다.

Python에서 struct.pack() 및 struct.unpack() 사용법에 대한 자세한 설명

추가되지 않으면 기본값은 @입니다. 즉, C 구조 및 메모리의 크기에 대해 기본 문자 순서(빅 엔디안 또는 리틀 엔디안)를 사용합니다. 정렬 방법도 머신(네이티브)과 일치합니다. 일부 기계에는 2비트 정수가 있고 일부 기계에는 4비트 정수가 있습니다. 일부 기계 메모리에는 4비트 정렬이 있고 일부는 n 비트 정렬이 있습니다(n은 알 수 없습니다.

다음과 같이 설명된 표준 옵션도 있습니다. 표준을 사용하는 경우 모든 유형에 대한 메모리 정렬이 없습니다.

예를 들어, 방금 애플릿의 후반부에서 사용된 형식 문자열의 첫 번째 비트는! , 이는 빅엔디안 모드 표준 정렬이므로 출력은 'x00x00x00x01x00x02x03'이며, 여기서 상위 비트 자체가 메모리의 상위 주소 비트에 배치됩니다.


위 내용은 Python에서 struct.pack() 및 struct.unpack() 사용법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.