Skip to main content

eseas is a Python package that serves as a wrapper for the jwsacruncher Java package. This tool allows users to process Demetra workspace XML files, create batch files, execute them, and collect the desired outputs into individual Excel files.

Project description

PyPI t Windows Ubuntu / Mac

Downloads Downloads Downloads

eseas

eseas is a Python package that acts as a wrapper for the jwsacruncher Java package. This tool allows users to process Demetra workspace XML files, create batch files, execute them, and collect the desired outputs into individual Excel files.

Installation

eseas

You can install the eseas package via pip:

pip install eseas -U

Prerequisites

jwsacruncher

eseas requires the jwsacruncher Java package. You can download it from the jwsacruncher GitHub releases page.

Setup Instructions

  1. Download the latest release of jwsacruncher from the releases page.
  2. Unzip the downloaded file.
  3. Note the path to the bin directory inside the unzipped folder.

After downloading jwsacruncher, you need to specify its location when using the Options function from the eseas package.

Usage

Here's an example of how to use the eseas package:

    from eseas import Seasonal, Options
    import time

    def main():
        # Specify the path to the jwsacruncher bin directory
        java_folder = r'../../Downloads/jwsacruncher-2.2.4/bin' 

        # [Optional] Java binary folder (where the Java executable exists)
        # This will be added to the environment PATH variable if provided.
        java_bin = r'/usr/bin'

        # Folder containing Demetra XML files
        demetra_source_folder = r"./demetra_source_folder"

        # Workspace where output files will be stored
        local_folder = r"./test_out"

        options = Options(
            demetra_source_folder,
            java_folder,
            local_folder,
            result_file_names=("sa", "s_f", "cal"),  # See "Demetra Components" below
            workspace_mode=True,
            file_name_explanation=True,
            java_bin=java_bin
        )

        # Initialize the Seasonal process
        seas = Seasonal(options)

        # Execute the two-step process
        seas.part1()
        time.sleep(10)  # Wait before executing part2
        seas.part2()

    if __name__ == "__main__":
        main()

Defining some parameters from .env file (NEW in version 1.0.0 )

You can define key parameters in an .env file located in the current directory where you run the script.

The function first checks whether the parameters are explicitly provided. If a parameter is not given in the function, it will automatically use the value from the .env file.

# `.env` file content (Example)

# Required if not given from function
java_folder = /Users/guest/app/jwsacruncher-2.2.6/bin
demetra_source_folder = ./eseas/data_for_testing/unix
local_folder = ./test_out

#Optional
java_bin = /usr/bin

Usage: Running the Script When a .env File Exists

from eseas import Seasonal, Options
import time

# Load options from the `.env` file
options = Options()

# Initialize and execute the seasonal adjustment process
m = Seasonal(options)
m.part1()
time.sleep(10)  # Pause before running part2
m.part2()

Usage: Overwriting demetra_folder from Function Call When .env File Exists

If a .env file is present, you can override the demetra_folder value by passing it directly in the function call.

from eseas import Seasonal, Options
import time

# Override `demetra_folder` from function call, ignoring the value in `.env`
options = Options(demetra_folder="SomeDemetraFolder")

# Initialize and execute the seasonal adjustment process
m = Seasonal(options)
m.part1()
time.sleep(10)  # Pause before running part2
m.part2()

Documentation

For more detailed information, refer to the following guides:

Documentation

How it Works

  1. Input Directory: The user specifies the directory of the Demetra workspace where XML files are located.
  2. Batch File Creation: The package creates batch files for all XML files in the specified directory.
  3. Execution: It runs the batch files using the jwsacruncher tool.
  4. Output Collection: The specified outputs are collected and compiled into individual Excel files for each XML file processed.

Acknowledgments

This package (eseas) is an independent Python wrapper that interacts with the jwsacruncher application.
Users must download jwsacruncher separately. This package is not affiliated with or derived from jwsacruncher.

jwsacruncher is a Java-based implementation of the .NET application WSACruncher. It is a command-line tool that allows users to re-estimate all multi-processing tasks defined in a Demetra workspace.

The workspace can be generated by:

  • Demetra+ (.NET)
  • JDemetra+ (Java)
  • Any compatible user tool

For more information, visit the jwsacruncher GitHub repository.

License

This project is licensed under the EUPL-1.2 License - see the LICENSE file for details.

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

eseas-1.0.8.tar.gz (32.0 kB view details)

Uploaded Source

Built Distribution

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

eseas-1.0.8-py3-none-any.whl (54.7 kB view details)

Uploaded Python 3

File details

Details for the file eseas-1.0.8.tar.gz.

File metadata

  • Download URL: eseas-1.0.8.tar.gz
  • Upload date:
  • Size: 32.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for eseas-1.0.8.tar.gz
Algorithm Hash digest
SHA256 1e8ae869e09f6ae62fbea666fc4fd6c5f74dc9f8533dbe9904ecaaac2c5b89a4
MD5 359a601fd87b6d5764b5c7730d98a986
BLAKE2b-256 bb145d3cc059842ff861bb300c4ca755424c721e7cb2c7aea9b39a917b49e8d4

See more details on using hashes here.

File details

Details for the file eseas-1.0.8-py3-none-any.whl.

File metadata

  • Download URL: eseas-1.0.8-py3-none-any.whl
  • Upload date:
  • Size: 54.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for eseas-1.0.8-py3-none-any.whl
Algorithm Hash digest
SHA256 bddee57c7288d9f1e2134a2561db429f827d51477b57a8e19e7986579e7e3755
MD5 0060b22338e6ace823a11b4f2378e162
BLAKE2b-256 990b95e177527e375813ecea3fc1f4de0ece3ee5000481b7f72ce549a0503cc4

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