https://github.com/vandlj/xmltojson
Tool for converting XML files into JSON format from digital archive of historical documents. The project is divided into separate Python modules for handling different kinds of data, including documents, persons, and archives.
https://github.com/vandlj/xmltojson
digital-archive digital-humanities full-text-search historical-documents json xml
Last synced: about 21 hours ago
JSON representation
Tool for converting XML files into JSON format from digital archive of historical documents. The project is divided into separate Python modules for handling different kinds of data, including documents, persons, and archives.
- Host: GitHub
- URL: https://github.com/vandlj/xmltojson
- Owner: VandlJ
- Created: 2024-11-08T09:20:16.000Z (11 months ago)
- Default Branch: main
- Last Pushed: 2024-12-23T17:57:07.000Z (10 months ago)
- Last Synced: 2025-10-13T01:32:06.830Z (about 21 hours ago)
- Topics: digital-archive, digital-humanities, full-text-search, historical-documents, json, xml
- Language: Python
- Homepage:
- Size: 1.28 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# XML to JSON Converter
## Table of Contents
- [XML to JSON Converter](#xml-to-json-converter)
- [Table of Contents](#table-of-contents)
- [Overview](#overview)
- [Features](#features)
- [Repository Structure](#repository-structure)
- [Usage](#usage)
- [Input Data Folder Structure](#input-data-folder-structure)
- [Setup Instructions](#setup-instructions)
- [Step 1: Clone the Repository](#step-1-clone-the-repository)
- [Step 2: Run the Conversion](#step-2-run-the-conversion)
- [Changes and Improvements](#changes-and-improvements)---
## Overview
This project provides a set of scripts and tools for converting XML files into JSON format. It is designed to work with different XML data sources and is fully customizable, supporting multiple conversion modules. The project is divided into separate Python modules for handling different kinds of data, including documents, persons, and archives.The solution includes:
- Various XML parsing methods for extracting data from different types of XML files.
- Tools to handle specific document types like archives, artwork, and persons.
- A flexible structure for easy conversion and integration with other systems.## Features
- **Custom Conversion Scripts**: Designed for different XML formats, including documents, persons, and archive links.
- **Flexible Data Handling**: The ability to handle text, metadata, and specific attributes such as aliases and references.
- **Modular Structure**: Each XML type is handled by separate scripts, making it easy to extend or modify.## Repository Structure
```bash
convert/
archiveLinkConvert.py # Handles conversion of archive link XMLs
artworkConvert.py # Handles artwork XML data
commonConvert.py # Contains common conversion utilities
personConvert.py # Handles conversion of person-related XMLs
docs/
pictures/ # Picture documentation related to the project
Analyza_SP.md # Analysis related documentation
documentaria_rudolphina.md # Project-specific documentation
model/
ArchiveLink.py # Data model for archive links
Document.py # Data model for documents
Person.py # Data model for person records
scripts/
main_convert.py # Main script to execute conversion
.gitignore # Git ignore configuration
README.md # This documentation file
```## Usage
To use this tool, you'll need Python and pip installed.
Then, run the following command:
```bash
pip install -r requirements.txt
```This will install necessary libraries to run the script. Then simply run the `main_convert.py` script with the appropriate options. Here are the main commands to run the program from the `XMLtoJSON` directory:
- Display help information:
```bash
python3 scripts/main_convert.py --help
```
or
```bash
python3 scripts/main_convert.py --h
```- Convert all types of XML files:
```bash
python3 scripts/main_convert.py --type all --input_path "path_for_input_data" --output_path "path_for_output_data"
```- Convert name-related XML files:
```bash
python3 scripts/main_convert.py --type names --input_path "path_for_input_data" --output_path "path_for_output_data"
```- Convert register-related XML files:
```bash
python3 scripts/main_convert.py --type registers --input_path "path_for_input_data" --output_path "path_for_output_data"
```- Convert archive-related XML files:
```bash
python3 scripts/main_convert.py --type archive --input_path "path_for_input_data" --output_path "path_for_output_data"
```### Input Data Folder Structure
The input data folder should be structured as follows:
```bash
input_data/
Archiv/ # Archive-related XML files
Regesten/ # Register-related XML files
Namen/ # Name-related XML files
Indicies/ # Index-related XML files
```## Setup Instructions
### Step 1: Clone the Repository
```bash
git clone https://github.com/VandlJ.git
cd XMLtoJSON
```### Step 2: Run the Conversion
To begin the conversion, use the main conversion script. For example, to convert all XML files:
```bash
python3 scripts/main_convert.py --type all --input_path "../test_data" --output_path "../test_data/output"
```You can also check out all available options and get detailed information by running:
```bash
python3 scripts/main_convert.py --help
```This command will start processing the XML files in the specified `--input_path` directory and output the results to the `--output_path` directory.
## Changes and Improvements
This project was inherited from another team, and we made several significant improvements and fixes to enhance its functionality and reliability:
1. **Error Handling: Spaces/Blank Characters for Indentation in Text - in Regesten Files**
- Previously, the Regesten JSON files had issues with spaces and blank characters causing indentation errors. We addressed this by splitting the "text" field into two distinct key values:
- `display`: This field is used for displaying text on the frontend, ensuring it retains the original formatting for readability.
- `processable`: This field contains a cleaner version of the text, optimized for computer processing and analysis.2. **Metadata Handling: Problem Metadata in Regesten**
- There were inconsistencies in capturing metadata elements such as `.p` in the Regesten files. Some elements were missing or incorrectly captured. We conducted a thorough review and ensured that all metadata elements are now accurately captured and processed in our iteration of the program.3. **Enhanced Interactivity: Add Information `onmouseover="highlightWords(event, '...')"` in Regesten**
- To improve the user experience, we added interactivity to the Regesten files. The `onmouseover` attribute was added to highlight words when hovered over. The processed data now includes:
```json
"names": [
{
"Aichholz_Johann": "Johann Aichholz",
"alias": "Johann Aichholz Ehrzney doctor"
},
{
"Strauben_Franz": "Franz Strauben",
"alias": "Frannzen Strauben"
}
]
```4. **Name Processing: Splitting First Name and Last Name via External Tool - GettyULAN**
- We integrated the project with an external tool, GettyULAN, to enhance name processing. This tool or API provides URL links to authors and returns one request per person. The application queries the SPARQL endpoint Getty, where each name is validated and processed. This integration ensures accurate and enriched author information.
- Additionally, we made the API for name splitting run asynchronously with caching, significantly increasing performance by reducing redundant requests and improving response times.5. **Unified Main Script for Conversion**
- We streamlined the conversion process by consolidating the three main Python scripts (previously used for different document types) into a single, unified script. This main script is now configurable via terminal options, allowing users to specify `--type`, `--input_path`, and `--output_path`. This change simplifies the execution and enhances the flexibility of the conversion process.6. **Improved Documentation and Setup Instructions**
- Updated the documentation to reflect the new changes and provide clear setup instructions. This includes detailed usage examples and the expected input data folder structure to ensure users can easily get started with the project.7. **Performance Enhancements and Bug Fixes**
- Conducted a comprehensive review of the codebase to identify and fix bugs. Implemented performance enhancements to ensure the conversion process is efficient and reliable.8. **Fixes in Archiv Type JSON Output**
- Corrected the handling of `hasSublink`, `linkTo`, and `next_link` variables in the output JSON files for the Archiv type. This ensures that these variables are accurately represented and linked in the JSON output.These improvements have significantly enhanced the functionality, usability, and reliability of the XML to JSON Converter project, making it more robust and user-friendly.