GitHub - peterhinch/micropython_data_to_py: A Python3 utility to convert an arbitrary binary file to Python source for storage in Flash (original) (raw)
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 be0xff, 0xd8
and jpeg_data[-2:] should be 0xff, 0xd9
.