Skip to main content

A Python package that converts ecospold XML formats to their Python equivalents and export the same data back to XML.

Project description

pyecospold

PyPI Status Python Version License

Read the documentation at https://pyecospold.readthedocs.io/ Tests Codecov

pre-commit Black

Installation

You can install pyecospold via [pip] from [PyPI]:

$ pip install pyecospold

ecospold1 Schema Updates

1.1

This library includes a new version of the schema definitions for ecospold1. Version 1.1 includes the following changes:

  • Changed the length restriction on referenceFunction.name to 255
  • Changed the length restriction on referenceFunction.synonym to 255
  • Changed the length restriction on category and subCategory to 255
  • Changed the length restriction on representativeness.productionVolume to 32.000
  • Made telephone optional

These changes were based on how this schema was being used by LCA software.

1.2

Corrected the handling of CAS numbers based on the official documentation:

  • A fixed size isn't required, zero-padding is optional and in any case is not used consistently by LCA software
  • Maximum length is 12, not 11
  • The first element has a minimum size of 2 digits, not 1

Usage

from pyecospold import parse_file_v1, save_ecopsold_file, Defaults

# Override defaults if needed, else skip. Defaults are already set.
Defaults.config_defaults("config.ini")  # Replace with your own config file

# Parse the required XML file to EcoSpold class.
ecoSpold = parse_file_v1("data/v1/v1_1.xml")  # Replace with your own XML file
ecoSpold
>> <Element {http://www.EcoInvent.org/EcoSpold01}ecoSpold at 0x1e667f7dae0>

# Change whatever attributes you need changing.
referenceFunction = ecoSpold.datasets[0].metaInformation.processInformation.referenceFunction
referenceFunction.amount
>> 1.0
referenceFunction.amount = 2.0
referenceFunction.amount
>> 2.0

# Save final EcoSpold class as an XML file, make sure root directory exists.
save_ecopsold_file(ecoSpold, "out/00001_new.xml")  # Replace with your own path

Config file

[parameters]
SCHEMA_V1_FILE=path/to/schemas/v1/EcoSpold01Dataset.xsd
SCHEMA_V2_FILE=path/to/schemas/v2/EcoSpold02.xsd

[Allocation]
allocationMethod=-1

[DataEntryBy]
qualityNetwork=1

[Dataset]
validCompanyCodes=CompanyCodes.xml
validRegionalCodes=RegionalCodes.xml
validCategories=Categories.xml
validUnits=Units.xml

[DataSetInformation]
impactAssessmentResult=false
internalVersion=1.0
version=1.0

[Exchange]
uncertaintyType=1

[ReferenceFunction]
infrastructureProcess=true

Contributing

Contributions are very welcome. To learn more, see the Contributor Guide.

License

Distributed under the terms of the BSD license, pyecospold is free and open source software.

Issues

If you encounter any problems, please file an issue along with a detailed description.

Credits

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

pyecospold-3.4.3.tar.gz (128.7 kB view details)

Uploaded Source

Built Distribution

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

pyecospold-3.4.3-py3-none-any.whl (137.9 kB view details)

Uploaded Python 3

File details

Details for the file pyecospold-3.4.3.tar.gz.

File metadata

  • Download URL: pyecospold-3.4.3.tar.gz
  • Upload date:
  • Size: 128.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.7

File hashes

Hashes for pyecospold-3.4.3.tar.gz
Algorithm Hash digest
SHA256 f7ffa683ed086b27f8eaaece746e1931ca929a528aaa2af230dd1ef6dfc40f3a
MD5 34135f3c3d0adbbdaab074c2f53f13c8
BLAKE2b-256 f3fff4f8c048f23e70a9204305268f1bb837c4639666ccf03b563b6a03db2ad9

See more details on using hashes here.

File details

Details for the file pyecospold-3.4.3-py3-none-any.whl.

File metadata

  • Download URL: pyecospold-3.4.3-py3-none-any.whl
  • Upload date:
  • Size: 137.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.7

File hashes

Hashes for pyecospold-3.4.3-py3-none-any.whl
Algorithm Hash digest
SHA256 acf980b62329e52d6b95b4b60e5be2bd5cc4fe3ae918fa92349c8138ceb394ca
MD5 71f4a6a2e9ae6f8236f69783fb160fdf
BLAKE2b-256 90e89fae10929a2ff9da8c2a77bb7beeb8394a64d012abc90b6f8bdfb9b4346b

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