/micropython_data_to_py

A Python3 utility to convert an arbitrary binary file to Python source for storage in Flash

Primary LanguagePythonMIT LicenseMIT

data_to_py.py

A means of storing read-only data in Flash, conserving RAM.

The utility runs on a PC and converts an arbitrary binary file into a Python source file. The generated Python file may be frozen as bytecode. Read-only data may thus be stored in Flash and accessed with little RAM use.

Please see also freezeFS - a utility by @bixb922 which allows a complete directory tree to be frozen and mounted as a filesystem.

Arguments

The utility requires two arguments, the first being the path to a file for reading and the second being the path to a file for writing. The latter must have a .py extension. If the output file exists it will be overwritten.

The Python output file

This instantiates a bytes object containing the data, which may be accessed via the file's data() function: this returns a memoryview of the data.

The use of a memoryview ensures that slices of the data may be extracted without using RAM:

import mydata  # file mydata.py (typically frozen)
d = mydata.data()  # d contains a memoryview
s = d[1000:3000]  # s contains 1000 bytes but consumes no RAM

A practical example is rendering a JPEG file to an LCD160CR display. The Python file img.py is generated using

$ ./data_to_py.py my_image.jpg img.py

The file img.py may then be frozen, although for test purposes it can just be copied to the target. The following code displays the image:

import lcd160cr
import img
lcd = lcd160cr.LCD160CR('Y')
lcd.set_orient(lcd160cr.PORTRAIT)
lcd.set_pen(lcd.rgb(0, 0, 0), lcd.rgb(0, 0, 0))
lcd.erase()
lcd.set_pos(0, 0)
jpeg_data = img.data()
lcd.jpeg(jpeg_data)  # Access the data and display it

Validation

The utility can accept any file type as input, so no validation is performed. If required, this must be done by the application at runtime. For example in the above code, to be suitable for the device jpeg_data[:2] should be 0xff, 0xd8 and jpeg_data[-2:] should be 0xff, 0xd9.