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-1.0.tar.gz (6.1 kB view details)

Uploaded Source

Built Distribution

cimrdf.py-1.0-py3.7.egg (13.0 kB view details)

Uploaded Source

File details

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

File metadata

  • Download URL: cimrdf.py-1.0.tar.gz
  • Upload date:
  • Size: 6.1 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-1.0.tar.gz
Algorithm Hash digest
SHA256 920c534afa5fc18537f57e7f05fb9af207e19fce52dce5f82604c887db861125
MD5 00de71e4a35e75461714e647380adbea
BLAKE2b-256 556e8e6e0796feb62d5b9cb41f0e3c32ef6a811a13de19f240ce4ebdc9a2585d

See more details on using hashes here.

File details

Details for the file cimrdf.py-1.0-py3.7.egg.

File metadata

  • Download URL: cimrdf.py-1.0-py3.7.egg
  • Upload date:
  • Size: 13.0 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-1.0-py3.7.egg
Algorithm Hash digest
SHA256 9450bf9f7ad8055cccc3d5216333be0f3528c8c0455106e97351213b550d1775
MD5 3c82123272c0143877b9c2cec7511ed3
BLAKE2b-256 d7904c28e7c57e7e3813bd8995e451667dae0f1c75093be6be6c0c50125cfb5e

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