Skip to main content

Generate Python data structures from CIM RDF profiles, parse and serialize CIM-compliant information objects, according to IEC 61970-501 standard

Project description

cimrdf.py

Generate Python data structures from CIM RDF profiles, parse and serialize CIM-compliant information objects, according to IEC 61970-501 standard.

Installing

$ git clone https://github.com/bressanmarcos/cimrdf.py.git
$ cd cimrdf.py
$ python setup.py install 

Using

  1. Create your RDF artifact with you preferred utils
  2. Convert it into Python data structures with:
cimrdfpy input_filename.xml output.py

Creating CIM RDF instances

3a. Use the generated classes from output.py to create your instances

from output import *

ei = EquivalentInjection()
ei.IdentifiedObject_mRID = 'EquivalentNW243'
t = Terminal()
t.Terminal_sequenceNumber = 1
t.Terminal_ConductingEquipment = ei

s = Switch()
s.Switch_normalOpen = True
s.IdentifiedObject_mRID = 'SW12'
t1 = Terminal()
t1.Terminal_sequenceNumber = 1
t1.Terminal_ConductingEquipment = s
t2 = Terminal()
t2.Terminal_sequenceNumber = 2
t2.Terminal_ConductingEquipment = s

cn = ConnectivityNode()
cn.IdentifiedObject_mRID = 'Node23'
cn.ConnectivityNode_Terminals = [t1, t] 
// This associates reciprocally Terminals t and t1 to ConnectivityNode cn, and vice versa

4a. Create a new document instance with all objects

new = DocumentCIMRDF([ei, t, s, t1, t2, cn])

The available functions are:

  • new.dump(): Pretty-Print the document to stdout
  • new.pack(): Get the document's ElementTree (xml.etree.ElementTree) instance
  • new.tostring(): Get the XML stringified version of the document
  • new.add_elements( ... ): Add new elements (one or a list) to the document

Parsing CIM RDF instances

3b. Use proper functions to parse file or string.

instances = fromstring(xmlstring)
print(instances)
// [list of instances]

The available functions are:

  • fromstring(xmlstring): Get list of instances from CIM RDF string
  • fromfile(filename): Get list of instances from CIM RDF file

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

cimrdf.py-2.0.tar.gz (6.9 kB view details)

Uploaded Source

Built Distribution

cimrdf.py-2.0-py3-none-any.whl (8.1 kB view details)

Uploaded Python 3

File details

Details for the file cimrdf.py-2.0.tar.gz.

File metadata

  • Download URL: cimrdf.py-2.0.tar.gz
  • Upload date:
  • Size: 6.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.6.9

File hashes

Hashes for cimrdf.py-2.0.tar.gz
Algorithm Hash digest
SHA256 d80b35eacc1abf4be2aad24fc655dc81c904201a4edb42250b2a910c77728fe9
MD5 1c17c6f3c9a74b3a82643b2fffa54fcc
BLAKE2b-256 f146da204567f276e149e799ad7017a83ed050d8b7a9bcba06fc84b085a55f28

See more details on using hashes here.

File details

Details for the file cimrdf.py-2.0-py3-none-any.whl.

File metadata

  • Download URL: cimrdf.py-2.0-py3-none-any.whl
  • Upload date:
  • Size: 8.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.6.9

File hashes

Hashes for cimrdf.py-2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 76000aac0954bbaea2aa1534a2e51ea5a1e971a0c049660a8bbf27e3f9137478
MD5 fb1fd7918051534ae49937435c19a2d5
BLAKE2b-256 891fc6bb1f060131252a0df5321d25aa4116574fd8951036b9dc99802e4b4144

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page