Skip to main content

Library for reading legacy DBF file with library data

Project description

Skoufas Library DBF Reader

Functions to read and convert from the DBF file used to track books in the Skoufas library

Columns in DBF file

Column Name (english) Name (Greek)
A01 Author surname, name, language Επώνυμο, Όνομα συγγραφέα
A02 title, has_cd Τίτλος, έχει CD
A03 subtitle, has_cd Υπότιτλος, έχει CD
A04 Dewey Ταξινομικός αριθμός
A05 entry_number αριθμός εισαγωγής
A06 translator, edition, entry_number μεταφραστής, έκδοση, αριθμός εισαγωγής
A07 edition, entry_number έκδοση, αριθμός εισαγωγής
A08 editor, entry_number εκδότης, αριθμός εισαγωγής
A09 editor place τοπος έκδοσης
A10 edition year ετος έκδοσης
A11 pages σελιδες
A12 topics, has_cd θέματα, έχει CD
A13 topics, has_cd θέματα, έχει CD
A14 topics, has_cd θέματα, έχει CD
A15 topics θέματα
A16 curator επιμελητής
A17 has_cd, copies, donations, offprint, volume, notes, isbn έχει CD, αντίτυπα, δωρεές, ανάτυπα, τόμοι/τεύχη, σημειώσεις, isbn
A18 material, entry_number, has_cd, copies, volume, notes, isbn συνοδευτικό υλικό, έχει CD, αντίτυπα, τόμοι/τεύχη, σημειώσεις, isbn
A19 isbn, entry_number isbn, αριθμός εισαγωγής
A20 topics, volume θέματα, τόμοι/τεύχη
A21 offprint, notes ανάτυπα, σημειώσεις
A22 topics, has_cd, isbn θέματα, έχει CD, isbn
A23 topics θέματα
A24 topics θέματα
A25
A26
A27
A28
A29
A30 has_cd, has_dvd, copies, donations, offprint, volume, material, notes, isbn έχει CD, έχει DVD, αντίτυπα, δωρεές, ανάτυπα, τόμοι/τεύχη, συνοδευτικό υλικό, σημειώσεις, isbn

Extractor functions

  • def authors_from_a01(a01: Optional[str]) -> list[str]
  • def copies_from_a17_a18_a30(a17: Optional[str], a18: Optional[str], a30: Optional[str]) -> Optional[int]
  • def curator_from_a16(a16: Optional[str]) -> Optional[str]
  • def dewey_from_a04_a05(a04: Optional[str], a05: Optional[str]) -> Optional[str]
  • def donation_from_a17_a30(a17: Optional[str], a30: Optional[str]) -> Optional[str]
  • def edition_from_a07(a07: Optional[str]) -> Optional[str]
  • def edition_year_from_a09_a10(a09: Optional[str], a10: Optional[str]) -> Optional[int]
  • def editor_from_a08_a09(a08: Optional[str], a09: Optional[str]) -> Optional[tuple[Optional[str], Optional[str]]]
  • def entry_numbers_from_a04_a05_a06_a07_a08_a18_a19(a04: Optional[str], a05: Optional[str], a06: Optional[str],a07: Optional[str],a08: Optional[str],a18: Optional[str],a19: Optional[str],) -> list[str]
  • def has_cd_from_a02_a03_a12_a13_a14_a17_a18_a22_a30(many_lines: Optional[list[Optional[str]]]) -> bool
  • def has_dvd_from_a30(many_lines: Optional[list[Optional[str]]]) -> bool
  • def isbn_from_a17_a18_a19_a22_a30(a17in: Optional[str], a18in: Optional[str], a19in: Optional[str], a22in: Optional[str], a30in: Optional[str]) -> Optional[str]
  • def language_from_a01(a01: Optional[str]) -> Optional[str]
  • def material_from_a18_a30(a18: Optional[str], a30: Optional[str]) -> Optional[str]
  • def notes_from_a17_a18_a21_a30(a17: Optional[str], a18: Optional[str], a21: Optional[str], a30: Optional[str]) -> Optional[str]
  • def offprint_from_a17_a21_a30(a17: Optional[str], a21: Optional[str], a30: Optional[str]) -> bool
  • def pages_from_a11(a11: Optional[str]) -> Optional[int]
  • def subtitle_from_a03(a03: Optional[str]) -> Optional[str]
  • def title_from_a02(a02: Optional[str]) -> Optional[str]
  • def topics_from_a12_to_a15_a20_a22_to_a24( many_lines: Optional[list[Optional[str]]],) -> list[str]
  • def translator_from_a06(a06: Optional[str]) -> Optional[str]
  • def volume_from_a17_a18_a20_a30(a17: Optional[str], a18: Optional[str], a20: Optional[str], a30: Optional[str]) -> Optional[str]

Checks required

  • Duplicated Entry Numbers (~800)
  • Non-numeric entry numbers (~130)
  • Missing entry numbers (~200)
  • Weird deweys and replacements (~300)
  • Translator corrections
  • author corrections
  • εκδοσεις
  • εκδοτης (field8)
  • field9
  • field10
  • isbn

Columns required

BookEntry

  • Title - Τίτλος
  • Subtitle - Υπότιτλος
  • Dewey - Ταξινομικός Αριθμός Dewey
  • Edition - Έκδοση
  • EditionDate - Έτος Έκδοσης
  • EditorId (FK: Editor)
  • Pages - Σελίδες Αριθμητικά
  • Volumes - Τόμοι/Τεύχη
  • Notes - Σημειώσεις
  • Material - Υλικό
  • HasCD - Έχει
  • HasDVD - Έχει
  • ISBN
  • ISSN
  • EAN
  • Offprint - ΑΝΑΤΥΠΟ

Author - Συγγραφέας

  • Name
  • Surname
  • Middlename
  • Fullname

Authorship (Many-to-Many)

  • AuthorId (FK: Author)
  • BookEntryId (FK: BookEntry)

Translator - Μεταφραστής

  • Name
  • Surname
  • Middlename
  • Fullname

Translation

  • TranslatorId (FK: Translator)
  • BookEntryId (FK: BookEntry)

Curator - Επιμελητής

  • Name
  • Surname
  • Middlename
  • Fullname

Curation

  • CuratorId (FK: Curator)
  • BookEntryId (FK: BookEntry)

Editor

  • Name
  • Place

Entry Numbers (one-to-many) - Αριθμοί Εισαγωγής

  • EntryNumber (unique)
  • BookEntryId (FK: BookEntry)
  • Copies

Topic - Θέμα

  • Name

BookInTopic (many-to-many)

  • TopicId (FK: Topic)
  • BookEntryId (FK: BookEntry)

Donor - Δωρητής

  • Name
  • Surname
  • Middlename
  • Fullname

Donation (Many-to-Many) - Δωρεά

  • DonorId (FK: Donor)
  • EntryNumberId (FK: EntryNumber)

Customer - Πελάτες

  • Name
  • Surname
  • Middlename
  • FullName
  • IdNumber
  • IdType
  • PhoneNumber
  • Email
  • Address

Loan - Δανεισμός

  • CustomerId (FK: Customer)
  • EntryNumberId (FK: EntryNumber)
  • StartDateTime
  • ExpectedEndDateTime
  • EndDateTime
  • Note

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

skoufas-dbf-reader-0.0.2rc136.post1.tar.gz (3.1 MB view details)

Uploaded Source

Built Distribution

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

File details

Details for the file skoufas-dbf-reader-0.0.2rc136.post1.tar.gz.

File metadata

File hashes

Hashes for skoufas-dbf-reader-0.0.2rc136.post1.tar.gz
Algorithm Hash digest
SHA256 6a48d41d1d3432dde17afc0a4f52f5e9fd8bb9f707687a59b020a5d5109d3d31
MD5 20b981d6875e7df043aa1be0098071c0
BLAKE2b-256 39e072e58f3d172348a250c4dee920a44556d49d42411e9ce1fb6b49b8102bd8

See more details on using hashes here.

File details

Details for the file skoufas_dbf_reader-0.0.2rc136.post1-py3-none-any.whl.

File metadata

File hashes

Hashes for skoufas_dbf_reader-0.0.2rc136.post1-py3-none-any.whl
Algorithm Hash digest
SHA256 874acee068cc73910512a8f8fde32f9705b7382db1b3d9390d7d0ff830d19454
MD5 f52b99f20e447c7608d5ba47ad47b3a7
BLAKE2b-256 99121e1ca3fd4da77c360dc5428d57511884ed8ee6325b0426e9ad56846c1465

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