Maison > développement back-end > Tutoriel Python > Description détaillée de l'utilisation de struct.pack() et struct.unpack() en Python

Description détaillée de l'utilisation de struct.pack() et struct.unpack() en Python

高洛峰
Libérer: 2017-03-16 16:02:01
original
13605 Les gens l'ont consulté

La structure dans python est principalement utilisée pour traiter les données de structure C. Lors de la lecture, elle est d'abord convertie en type string de Python, puis convertie en type structuré de Python, tel. comme tuple ou quelque chose comme ça ~. Généralement, les canaux d'entrée proviennent de fichiers ou de flux binaires réseau.

1.struct.pack() et struct.unpack()

Pendant le processus de conversion, une chaîne de format(pour mat strings), utilisé pour spécifier la méthode et le format de conversion.

Parlons des principales méthodes :

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

Mettez v1, v2 et autres paramètres La valeur est enveloppé en une seule couche et la méthode d'emballage est spécifiée par fmt. Les paramètres encapsulés doivent être strictement conformes à fmt. Enfin, une chaîne enveloppée est renvoyée.

1.2 struct.unpack(fmt,string)

Comme son nom l'indique, décompressez. Par exemple, pack est emballé, puis déballé peut être utilisé pour déballer. Renvoie un tuple obtenu en décompressant les données (chaîne), même s'il n'y a qu'une seule donnée, elle sera décompressée en un tuple. Parmi eux, len(string) doit être égal à calcsize(fmt), ce qui implique une fonction calcsize. struct.calcsize(fmt) : Ceci est utilisé pour calculer la taille de la structure décrite au format fmt.

La chaîne de format est constituée d'un ou plusieurs caractères de format. Pour la description de ces caractères de format, veuillez vous référer au manuel Python comme suit :

Description détaillée de lutilisation de struct.pack() et struct.unpack() en Python

2. . Exemple de code

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)
Copier après la connexion

Paramètres du premier pack 1,2,3 Avant l'empaquetage, 1,2,3 appartiennent évidemment à entiertype de données 🎜>, Après emballage, elle devient une chaîne binaire structurée en C et, une fois convertie en type de chaîne Python, elle s'affiche sous la forme « x01x00x00x00x02x00x03 ». Puisque cette machine est little-endian (« little- endian », veuillez vous référer ici pour connaître la différence entre big-endian et little-endian, de sorte que les bits hauts sont placés dans le segment d'adresse bas. i représente le type int dans la structure C, donc cette machine La machine occupe 4 bits, et 1 est représenté par 01000000 ; h représente le type court dans la structure C, occupant 2 bits, il est donc représenté par 0200 ; le type char signé dans la structure C, occupant 1 bit, il est donc représenté par 03.

La conversion des autres structures est similaire. Pour certaines structures spéciales, vous pouvez vous référer au Manuel du. document officiel.

Au début de la chaîne Format, il y a un caractère facultatif pour déterminer le big endian et le little endian , la liste est la suivante :

Description détaillée de lutilisation de struct.pack() et struct.unpack() en Python<.> S'il n'est pas ajouté, la valeur par défaut est @, c'est-à-dire en utilisant l'ordre natif des caractères (big endian ou little endian), pour la taille de la structure C et de la mémoire. La méthode d'alignement est également cohérente avec la machine (native). Par exemple, certaines machines ont un entier de 2 bits et certaines machines ont un entier de quatre bits ; certaines mémoires de machines ont un alignement sur quatre bits, et certaines ont un alignement sur n bits ( n est inconnu, je ne sais pas combien).

Il existe également une option standard, décrite comme suit : Si vous utilisez standard, il n'y a aucun alignement de mémoire pour aucun type.

Par exemple, dans la seconde moitié de l'applet tout à l'heure, le premier bit de la chaîne de format utilisé est ! , qui est l'alignement standard du mode big-endian, donc la sortie est 'x00x00x00x01x00x02x03', dans laquelle le bit haut lui-même est placé dans le bit d'adresse haute de la mémoire.


Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal