Skip to main content

An inventory system for self-help repair shops

Project description

Inventory

Python module and scripts for inventory software.

Also look at the data in the subdirectory sample-data or a real-life data set (unfortunately private due to not owned images) and the corresponding GUI.

Motivation

In a community-run workshop, e.g. a self-help bike repair workshop, there are a lot of different things stored, a lot more than a newcomer — or a long-time user as well — can memorize. That's why a good sorting system is very helpful. There are limitations to a good physical sorting though:

  1. things can belong to different categories
  2. available space restrictions force us putting small things to each other, breaking association by topic
  3. if you look for the correct place for a thing, you might not know what it is called or what it is good for. Than categories and signs help less.
  4. Newcomers are not able to sort things and clean up the workshop. This tedious task is usually restricted to the people that have been involved for a long time while they are also a bottleneck for a lot of other activity.

There this inventory should help.

  1. Each thing is listed with many names and an "official" name. That way you have higher chances to find your thing and its place if the alternative name you would use intuitively is also listed. This should enable newcomers to independently clean up and learn about the existing things at the same time.
  2. Each label (that is big enough) contains a picture to identify things from outside (intransparent) boxes as well.
  3. Each thing can be found by one of its names alphabetically, by several categories, by English or German name, by looking at pictures in the storage. Not a single categorization to be limited to.

Data

For example data see the directory sample-data or the data repository. (Currently outdated.) The data format is a specific directory structure with specific file names:

  • schema.yaml: describes how locations in this workshop are defined. See sample_data for details.
  • preferences.yaml: general options for this data. See sample_data for details.
  • directory things: directory with the actual data. Includes one directory per thing.
  • things/someID/thing.yaml: name, description, ... about one thing. This should be (largely) workshop-independent.
  • things/someID/location.yaml: where this thing is stored in this workshop
  • things/someID/sign.yaml: how the sign on the box for this thing looks in this workshop
  • things/someID/image.*: an image for this thing. Usually workshop-independent.

No keys in things/someID/*yaml are mandatory. Therefore, code that uses the data has to handle missing data.

Functionalities

With this repository alone, entering data means writing the json files by hand. For a GUI method, see flinventory-GUI.

The scripts are

  • generate_labels.py for creating signs that can be printed and glued to the boxes. The size and formatting of the signs happens in things/*/sign.json. Also it creates a list of all names of all things with a reference to their location. This list is in markdown and can be converted with pandoc to a printable (multiple page) list. For details see the help messages.
  • datacleanup.py for various tasks for reformatting the yaml files. This is helpful to have a bit of standardisation to avoid big git diffs when the yaml files are read and written again. For details see the help messages.

Project details


Download files

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

Source Distribution

flinventory-0.3.0.tar.gz (190.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

flinventory-0.3.0-py3-none-any.whl (194.3 kB view details)

Uploaded Python 3

File details

Details for the file flinventory-0.3.0.tar.gz.

File metadata

  • Download URL: flinventory-0.3.0.tar.gz
  • Upload date:
  • Size: 190.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: pdm/2.22.3 CPython/3.12.9 Linux/6.12.14

File hashes

Hashes for flinventory-0.3.0.tar.gz
Algorithm Hash digest
SHA256 ec9dabbbb728b3fd8807a1f33dda9e22aae7c589e1048eae30ed3b087e060763
MD5 588bf19f5220a919dea94c9e87710867
BLAKE2b-256 07c341dcbb17900a1cf81f0a0f885c88790088cf9d145931150da5c4a6f0734d

See more details on using hashes here.

File details

Details for the file flinventory-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: flinventory-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 194.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: pdm/2.22.3 CPython/3.12.9 Linux/6.12.14

File hashes

Hashes for flinventory-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 bb80caf9553463de795169f49dc8933a08a7dacb94e4d4947c891320ffd1a323
MD5 75559d6a1d78508eb75f562beacc16e9
BLAKE2b-256 c4d6e70dd085f16ebaf1f66d7506f6f8d700f2942b68a2326362b8da144eebf6

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page