Skip to content

A python program to generate QR codes based on a Google Sheets document which has asset_guid and asset_name

Notifications You must be signed in to change notification settings

josephedwardchang/QRCodeGenerator

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

66 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

QR Code Generator

A python program to generate QR codes from Google Sheets document, IFC and CSV files.

Installation

Pre-requisites

pip install -r requirements.txt

In order to be able to use IFC as input file you will need to install the python package IfcOpenShell. You can find the appropriate version of this module here. Download the module and place the extracted archive in the site-packages folder of your Python distribution.

The QR code generato uses the arial.ttf font. You can download it here.

Steps for generating the QR code from Google Sheets document, IFC and CSV files

  1. Create the input file following the istruction below:

    • Google Sheets document and CSV file MUST contain at least these three columuns: asset_name, asset_guid and size, where size refers to the size in pixel of the QR code. By default a size of 10 is considered, however the following options have been also implemented small:5, medium:10, large:15. An example of input file can be found here. In order to run the script using the google sheet option, please be aware that you must have the crediatial json file and the right to edit the document;
    • In the IFC file, the asset name can be specified in the Data property definition. If it's not provided, the name will be generated by following the BDNS naming convention (if possible) using the Revit Tag number.
  2. Update the templates under src/qrtemplates as required. The QR Code should include the site name as well as be minified to comply with current BDNS standards.

  3. To launch the application move into the src folder

    • To run the Django-based web app use the following command

    python manage.py runserver

    • If you want to run the application locally use instead

    python run_qrcgeneration.py [args]

Command line options

  ___  ____   ____          _       ____            
 / _ \|  _ \ / ___|___   __| | ___ / ___| ___ _ __  
| | | | |_) | |   / _ \ / _` |/ _ \ |  _ / _ \ '_ \ 
| |_| |  _ <| |__| (_) | (_| |  __/ |_| |  __/ | | |
 \__\_\_| \_\\____\___/ \__,_|\___|\____|\___|_| |_|
                                                    

usage: run_qrcgeneration.py [-h] [-v] [-t INPUTTYPE] [-s GSHEETID] [-w WORKSHEET] [-j CREDSFILE] [-f FILENAME] [-o OUTPUT] [-b BDNSFLAG]

optional arguments:
  -h, --help            show this help message and exit
  -v, --verbose         increase the verbosity level
  -t INPUTTYPE, --inputtype INPUTTYPE
                        input type which can be gsheet, ifc or csv
  -s GSHEETID, --gsheetid GSHEETID
                        google spreadsheet ID
  -w WORKSHEET, --worksheet WORKSHEET
                        google spreadsheet worksheet
  -j CREDSFILE, --credsfile CREDSFILE
                        credential json file
  -f FILENAME, --filename FILENAME
                        input IFC or CSV file name
  -o OUTPUT, --output OUTPUT
                        output folder for the generated QR code
  -b BDNSFLAG, --bdnsflag BDNSFLAG
                        data validation against the BDNS initiative
  -m MinifiedFLAG, --minified MinifiedFLAG
                        bool True if using minified format

Validation against the BDNS initiative

By default BDNSFLAG =True and this allow to:

  1. Check the device instance globally unique identifier (GUID) format and its uniqueness
  2. Check that the device name rule is fulfilled
  3. Check if the abbreviation used is compliant with the BDSN Abbreviations Register

These tests are in place for warning purposes. If the device is not compliant, the QR code label will appear in red colour.

By default MinifiedFLAG =False and this:

  1. Encodes the json stripped of whitespace
  2. Uses src/qrtemplates/*.min.* template files, instead of non-minified templates

CSV input file must add "asset.site" column to encode the site property in the json

Reference

BDNS initiative

About

A python program to generate QR codes based on a Google Sheets document which has asset_guid and asset_name

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 93.5%
  • HTML 6.5%