Skip to main content

Packed binary data for networking.

Project description


NetStruct is a struct <>_-like module for Python designed to make it a bit easier to send and received packed binary data.

NetStruct is available under the Apache License, Version 2.0.


NetStruct can be installed using pip.

pip install netstruct

You can also grab the latest code from the git repository:

git clone git://

NetStruct runs on Python 2.6+. Python 3 should work as well, but is currently untested.

Differences from struct

NetStruct has two differences from struct.

First, it defaults to using network byte-order, rather than native byte-order, on the assumption that you’ll be using it to send data over the network and, thus, it’s saving you time.

Additionally, the generated strings don’t have any padding when using non-native byte-order.

Second, NetStruct supports a new formatting character, the dollar sign ($). The dollar sign represents a variable-length string, encoded with its length preceeding the string itself. To accomplish this, the formatting character directly before the dollar sign is assumed to represent the string’s length.


This is as basic as it gets.

>>> import netstruct
>>> netstruct.pack("b$", "Hello World!")
'\x0cHello World!'


>>> netstruct.unpack("b$", "\x0cHello World!")
['Hello World!']

You can get a bit more complex, if you’d like.

>>> netstruct.pack("ih$5b", 1298, "largeBiomes", 0, 0, 1, 0, 8)

And, of course, you can unpack complex data too.

>>> netstruct.unpack("bh$h$i", "'\x00\x07stendec\x00\tlocalhost\x00\x00c\xdd")
[39, 'stendec', 'localhost', 25565]

You just have to be sure to use a long enough string.

>>> netstruct.unpack("bh$h$i", "'\x00\x07stendec\x00\tlocalhost\x00")
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "site-packages/", line 275, in unpack
    return NetStruct(format).unpack(data)
  File "site-packages/", line 165, in unpack
    raise error("unpack requires a string argument of length %d" % (len(data) + out))
struct.error: unpack requires a string argument of length 25

But wait, you say. How am I supposed to provide a long enough string to unpack the data when I can’t possibly know the length ahead of time? Simply put, you can know the length.

>>> it = netstruct.iter_unpack("ih$5b")

The iter_unpack function returns an iterator. Each time you call that iterator’s .next() or .send() methods, it can return one of two values. Either it’ll return the number of bytes it wants you to read next, or it’ll return the completed object.

Let’s continue from above, shall we?

>>> it.send("\x00\x00\x05\x12\x00\x0b")
>>> it.send("largeBiomes")
>>> it.send("\x00\x00\x01\x00\x08   more")
[1298, 'largeBiomes', 0, 0, 1, 0, 8]

There. I’ve sent enough data, so it returned the completed list of the unpacked data. At this point, I can take my data, and do whatever it is I want with it.

But wait! I just sent too much data to that iterator, and now I’ve lost some of my string, haven’t I? That’s not a problem either. You can call the iterator one final time and it will return the unconsumed remainder of the data.

'   more'

It’s just that simple. Of course, not everyone likes iterators, even if they are quicker and less memory intensive than a class instance. NetStruct is prepared, with its Unpacker class and obj_unpack. Let’s try that last example one more time.

>>> obj = netstruct.obj_unpack("ih$5b")
>>> obj.remaining
>>> obj.feed("\x00\x00\x05\x12\x00\x0b")
>>> obj.feed("largeBiomes")
>>> obj.feed("\x00\x00\x01\x00\x08   more")
>>> obj.result
[1298, 'largeBiomes', 0, 0, 1, 0, 8]
>>> obj.unused_data
'   more'


Project details

Release history Release notifications

History Node


History Node


This version
History Node


History Node


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Filename, size & hash SHA256 hash help File type Python version Upload date (5.1 kB) Copy SHA256 hash SHA256 Source None Oct 27, 2012

Supported by

Elastic Elastic Search Pingdom Pingdom Monitoring Google Google BigQuery Sentry Sentry Error logging CloudAMQP CloudAMQP RabbitMQ AWS AWS Cloud computing DataDog DataDog Monitoring Fastly Fastly CDN DigiCert DigiCert EV certificate StatusPage StatusPage Status page