Skip to content

Latest commit

 

History

History
82 lines (57 loc) · 4.37 KB

README.md

File metadata and controls

82 lines (57 loc) · 4.37 KB

KNV Address Organizer

What

This project serves as an example workflow for organizing addresses generated from KNV (german wholesale book distributor) and saving them in CSV files. It works with customer information that has been exported with pcbis.de (called Stammadressen) and invoices issued by Fitbis as well.

Why

We needed a solution that's flexible enough for all employees to work with (who are using Kubuntu which helps) while being easily maintainable through the CLI.

Getting started

Quick setup

Simply run bash setup.bash and you're set.

Manual setup

Create a virtual environment with python3 and activate it:

virtualenv -p python3 .venv
source .venv/bin/activate

Now, install all python packages with pip install -r requirements.txt - or just doit as its the only dependency at the moment: pip install doit.

Usage

With doit list you'll be presented with available tasks:

$ doit list
backup    Backs up main file
count     Counts entries in main file
dedupe    Removes duplicates from main file
diff      Processes changes made to CSV files
export    Exports all data from main file to CSV files
fuzzy     Detects possible duplicates
import    Imports changes to CSV files into main file
merge     Merges lists into main file
print     Prints CSV tables from main file
restore   Restores main file
sort      Sorts main file
split     Splits main file into lists

After retrieving Stammadressen.xls (customer data), Fakturierung.hmtl (invoices) and Orders_<storeID>_*.csv (online), put them in their respective directory inside src and run bash src/main.bash from CLI - after that, it's up to you (pull requests are welcome :fox:).

Troubleshooting

Especially when extracting outdated information, at some point or another challenges will arise:

Scraping data from KNV's online shop

Gathering data from shopkonfigurator is easy - from the main view of your shop's orders (meine Shops -> <your shop> -> Aufträge), click on Daten-Export and choose Auftragsdaten, enter the relevant period and hit exportieren.

Scraping invoices

First of all, exporting those invoices may take some time. When we decided to do this, there were over 8000 records, going back to 2010. Fitbis isn't of much help there, limiting us to 50 records per page ..

Along the way, we will need the help of our browser's 'Developer Tools' (which are included in Firefox as well as Chrome).

While the whole customer database (Stammadressen) may be exported in one fell swoop (Weitere Funktionen -> Stammadressen -> Anzeigen, then Funktionen -> Alle Stammadressen exportieren), this doesn't apply to invoices - but were there's a will there's a way:

  1. Log into pcbis.de, then Fitbis -> Fakturierung -> Anzeigen will show you the ten most recent invoices.
  2. Open the dropdown for entries per page (Einträge pro Seite), right-click on one of those numbers (eg '50') and select Inspect Element (Firefox) Inspect (Chrome).
  3. Looking at the selected li element's onclick attribute, we notice the following: setInputFieldDynamic( 'comtitlesPerPageHeader', '50','50').
  4. Double-click the onclick attribute and change both integers to something >= the total number of invoices (eg '10000').
  5. Wait for it .. boom! Save the page with CTRL + S.

One size doesn't fit all

We never intended to release this, so think of this project as a boilerplate to get you started.

Roadmap

Currently, the initial database was created before the decision to release this was made - so this is somewhat incomplete. Address organization already works the way it should .. but these features are planned:

  • Additional comments
  • Data extraction for pcbis.de
  • Tutorial on downloading invoices from pcbis.de
  • Diffing CSV files from employees, adding changes automagically
  • Finding possible duplicates through fuzzysearch
  • More modular setup (rules about converting phone numbers, cities, wrong categories ..)

©️ Fundevogel Kinder- und Jugendbuchhandlung