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 :
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)
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.
<.> 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!