ホームページ バックエンド開発 Python チュートリアル Python でのパックとアンパックの使用法の概要

Python でのパックとアンパックの使用法の概要

Aug 21, 2017 pm 02:47 PM
python

ファイルへのアクセスやソケット操作など、バイナリデータを処理するために Python を使用する必要がある場合があります。このとき、Python の struct モジュールを使用して C 言語で構造体を処理できます。

struct モジュール内の 3 つの最も重要な関数は、pack()、unpack()、calcsize() です

pack(fmt, v1, v2, ...) は、指定された形式 (fmt) に従ってデータをカプセル化します。 string (実際にはC構造に似たバイトストリームです)

unpack(fmt, string) 指定された形式(fmt)に従ってバイトストリーム文字列を解析し、解析されたタプルを返します

calcsize(fmt) 指定された数を計算しますformat (fmt) が占有するメモリのバイト数は次のとおりです:

Format C 型 Python バイト数

x パッドバイト 値なし 1

c 長さ 1 の char 文字列 1

b signed char integer 1

B unsigned char integer 1

? _Bool bool 1

h short integer 2

H unsigned short integer 2

i int integer 4

I unsigned int integer または long 4

l long inティーガー4

L unsigned long long 4

q long long long 8

Q unsigned long long long 8

f float float 4

d double float 8

s char[] string 1

p char[] string 1

P void * long

注 1.q と Q は、マシンが 64 ビット動作をサポートしている場合にのみ興味深いです

注 2. 各形式の前に番号を示す数字を付けることができます

注 3.s 形式は特定の長さの文字列を示し、4s は長さ 4 の文字列を表しますが、p はパスカル文字列を表します

注 4。 P はポインタの変換に使用され、その長さはマシン語の長さに関連します

注 5。最後の 1 つは、ポインター型を表すために使用され、4 バイトを占めます

C の構造体とデータを交換するには、一部の C または C++ コンパイラーが、通常は 4 バイトの単位で 32 ビット システムのバイト アライメントを使用することも考慮する必要があります。なので、構造体はローカル マシンのバイト オーダーに従って変換されます。フォーマットの最初の文字を使用してアライメントを変更できます。定義は次のとおりです。バイト数

= 元のバイト数によるネイティブ標準標準

< 元のバイト数によるビッグエンディアン標準標準

!エンディアン)

standard Press '@5s6sif' と同様に、fmt の最初の位置に元のバイト数

が使用されます

例 1:

構造は次のとおりです:

struct Header
{
    unsigned short id;
    char[4] tag;
    unsigned int version;
    unsigned int count;
}
ログイン後にコピー

は上記の構造データを受け取りましたsocket.recv は文字列 s に存在します。今度はそれを解析する必要があります。unpack() 関数を使用できます。

import struct
id, tag, version, count = struct.unpack("!H4s2I", s)
ログイン後にコピー

上記の形式文字列では、 ! は解析にネットワーク バイト オーダーを使用することを意味します。データはネットワークからのものです。受信時、ネットワーク上で送信されるときはネットワーク バイト オーダーになります。次の H は符号なしの短い ID を表し、4s は 4 バイトの長さの文字列を表し、2I は 2 つの符号なし int 型データを表します。アンパックするだけで、情報が ID、タグ、バージョン、カウントに保存されました

同様に、ローカル データを構造体形式にパックすることも非常に便利です:

ss = struct.pack("!H4s2I", id, tag, version, count);
ログイン後にコピー

Pack 関数は ID、タグ、バージョンを入れます。 、および count は、指定された形式に従ってヘッダー構造体に変換されます。ss は文字列 (実際には c 構造体に似たバイト ストリーム) になります。この文字列は、socket.send(ss) を通じて送信できます。

例2:

import struct
a=12.34
#将a变为二进制
bytes=struct.pack(&#39;i&#39;,a)
ログイン後にコピー

このとき、bytesは文字列stringであり、その文字列はバイト単位のaのバイナリ記憶内容と同じです。

次に、逆の操作を実行し、既存のバイナリ データ バイト (実際には文字列) を Python データ型に変換します:

#unpack はタプルを返すことに注意してください!!

a,=struct.unpack(&#39;i&#39;,bytes)
ログイン後にコピー

複数で構成されている場合は、次のように構成されますデータは次のようになります:

a=&#39;hello&#39;
b=&#39;world!&#39;
c=2
d=45.123
bytes=struct.pack(&#39;5s6sif&#39;,a,b,c,d)
ログイン後にコピー

この時点のバイトはバイナリ形式のデータであり、binfile.write(bytes) などのファイルに直接書き込むことができます

その後、必要なときに読み取ることができますそれを bytes=binfile .read()

し、struct.unpack() を通じて Python 変数にデコードします。

a,b,c,d=struct.unpack(&#39;5s6sif&#39;,bytes)
ログイン後にコピー

'5s6sif' は fmt と呼ばれ、数字と文字で構成される書式設定された文字列です。 5 文字の文字列。2i は 2 つの整数を意味します。使用可能な文字と型は次のとおりです。ctype は、Python の型に 1 対 1 で対応できることを意味します。

注: バイナリ ファイルの処理中に問題が発生しました

バイナリ ファイルを処理するときは、次のメソッドを使用する必要があります:

binfile=open(filepath,&#39;rb&#39;)    
#读二进制文件
binfile=open(filepath,&#39;wb&#39;)   
#写二进制文件
ログイン後にコピー

それでは、binfile=open(filepath,'r') の結果の違いは何でしょうか?

2 つの違いがあります:

まず、「r」を使用するときに「0x1A」に遭遇すると、それはファイルの終わり、つまり EOF とみなされます。 「rb」を使用すると、この問題は発生しません。つまり、バイナリで書き込み、テキストで読み出す場合、「0X1A」が存在するとファイルの一部だけが読み出されます。 「rb」を使用すると、ファイルの最後まで読み取られます。

2 番目に、文字列 x=’abcndef’ の場合、len(x) を使用して長さを 7 にします。n を改行文字と呼び、実際には「0X0A」です。テキストモードである「w」で記述すると、「0X0A」は Windows プラットフォーム上で自動的に「0X0D」、「0X0A」の 2 文字に変更されます。つまり、実際のファイル長は 8 になります。 「r」テキスト モードで読み取ると、元の改行文字に自動的に変換されます。書き込み時に「wb」バイナリモードに変更すると、1文字は変更されず、読み取り時にそのまま読み込まれます。したがって、テキスト モードで書き込み、バイナリ モードで読み取る場合は、この余分なバイトを考慮する必要があります。 「0X0D」は復帰文字とも呼ばれます。 Linux では変化しません。 Linux は改行を表すために「0X0A」のみを使用するためです。

以上がPython でのパックとアンパックの使用法の概要の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

XMLをPDFに変換できるモバイルアプリはありますか? XMLをPDFに変換できるモバイルアプリはありますか? Apr 02, 2025 pm 08:54 PM

XMLをPDFに直接変換するアプリケーションは、2つの根本的に異なる形式であるため、見つかりません。 XMLはデータの保存に使用され、PDFはドキュメントを表示するために使用されます。変換を完了するには、PythonやReportLabなどのプログラミング言語とライブラリを使用して、XMLデータを解析してPDFドキュメントを生成できます。

XML形式を開く方法 XML形式を開く方法 Apr 02, 2025 pm 09:00 PM

ほとんどのテキストエディターを使用して、XMLファイルを開きます。より直感的なツリーディスプレイが必要な場合は、酸素XMLエディターやXMLSPYなどのXMLエディターを使用できます。プログラムでXMLデータを処理する場合、プログラミング言語(Pythonなど)やXMLライブラリ(XML.ETREE.ELEMENTTREEなど)を使用して解析する必要があります。

推奨されるXMLフォーマットツール 推奨されるXMLフォーマットツール Apr 02, 2025 pm 09:03 PM

XMLフォーマットツールは、読みやすさと理解を向上させるために、ルールに従ってコードを入力できます。ツールを選択するときは、カスタマイズ機能、特別な状況の処理、パフォーマンス、使いやすさに注意してください。一般的に使用されるツールタイプには、オンラインツール、IDEプラグイン、コマンドラインツールが含まれます。

携帯電話用の無料のXMLからPDFツールはありますか? 携帯電話用の無料のXMLからPDFツールはありますか? Apr 02, 2025 pm 09:12 PM

モバイルには、単純で直接無料のXMLからPDFツールはありません。必要なデータ視覚化プロセスには、複雑なデータの理解とレンダリングが含まれ、市場のいわゆる「無料」ツールのほとんどは経験がありません。コンピューター側のツールを使用したり、クラウドサービスを使用したり、アプリを開発してより信頼性の高い変換効果を取得することをお勧めします。

XMLのコメントコンテンツを変更する方法 XMLのコメントコンテンツを変更する方法 Apr 02, 2025 pm 06:15 PM

小さなXMLファイルの場合、注釈コンテンツをテキストエディターに直接置き換えることができます。大きなファイルの場合、XMLパーサーを使用してそれを変更して、効率と精度を確保することをお勧めします。 XMLコメントを削除するときは注意してください。コメントを維持すると、通常、コードの理解とメンテナンスが役立ちます。高度なヒントは、XMLパーサーを使用してコメントを変更するためのPythonサンプルコードを提供しますが、特定の実装を使用するXMLライブラリに従って調整する必要があります。 XMLファイルを変更する際のエンコード問題に注意してください。 UTF-8エンコードを使用して、エンコード形式を指定することをお勧めします。

XMLの変更にはプログラミングが必要ですか? XMLの変更にはプログラミングが必要ですか? Apr 02, 2025 pm 06:51 PM

XMLコンテンツを変更するには、ターゲットノードの正確な検出が必要であるため、プログラミングが必要です。プログラミング言語には、XMLを処理するための対応するライブラリがあり、APIを提供して、データベースの運用などの安全で効率的で制御可能な操作を実行します。

携帯電話でXMLをPDFに変換するとき、変換速度は高速ですか? 携帯電話でXMLをPDFに変換するとき、変換速度は高速ですか? Apr 02, 2025 pm 10:09 PM

Mobile XMLからPDFへの速度は、次の要因に依存します。XML構造の複雑さです。モバイルハードウェア構成変換方法(ライブラリ、アルゴリズム)コードの品質最適化方法(効率的なライブラリ、アルゴリズムの最適化、キャッシュデータ、およびマルチスレッドの利用)。全体として、絶対的な答えはなく、特定の状況に従って最適化する必要があります。

画像に変換されたXMLのサイズを制御する方法は? 画像に変換されたXMLのサイズを制御する方法は? Apr 02, 2025 pm 07:24 PM

XMLを介して画像を生成するには、XMLのメタデータ(サイズ、色)に基づいて画像を生成するために、ブリッジとしてグラフライブラリ(枕やJFreechartなど)を使用する必要があります。画像のサイズを制御するための鍵は、&lt; width&gt;の値を調整することです。および&lt; height&gt; XMLのタグ。ただし、実際のアプリケーションでは、XML構造の複雑さ、グラフ描画の細かさ、画像生成の速度とメモリ消費の速度、および画像形式の選択はすべて、生成された画像サイズに影響を与えます。したがって、グラフィックライブラリに熟練したXML構造を深く理解し、最適化アルゴリズムや画像形式の選択などの要因を考慮する必要があります。

See all articles