Skip to main content

nemwriter

Project description

nem-writer

PyPI version PyPi downloads

Write meter readings to AEMO NEM12 (interval metering data) and NEM13 (accumulated metering data) data files

Accumulated Data (NEM13)

from datetime import datetime
from nemwriter import NEM13

m = NEM13(to_participant='123')
ch = m.add_reading(nmi='123',
                    nmi_configuration='E1B1B2',
                    register_id='1',
                    nmi_suffix='E1',
                    previous_read=412,
                    previous_read_date=datetime(2017,1,1),
                    previous_quality_method='A',
                    current_read=512,
                    current_read_date=datetime(2017,2,1),
                    current_quality_method='A',
                    quantity=100,
                    uom='kWh'
                    )
output = m.output_csv(file_path='output.csv')

Will output:

100,NEM13,201701010101,,123
250,123,E1B1B2,1,E1,,,E,412,201701010000,A,,,512,201702010000,A,,,100,kWh,,,
900

Interval Data (NEM12)

from datetime import datetime
from nemwriter import NEM12

m = NEM12(to_participant='123')
readings = [
    # read end, read value, quality method, event code, event desc
    [datetime(2004, 4, 18, 0, 30), 10.1, 'A', 79, 'Power Outage Alarm'],
    [datetime(2004, 4, 18, 1, 0), 11.2, 'A'],
    [datetime(2004, 4, 18, 1, 30), 12.3, 'A'],
    [datetime(2004, 4, 18, 2, 0), 13.4, 'A'],
]

ch = m.add_readings(nmi='123',
                    nmi_configuration='E1B1B2',
                    nmi_suffix='E1', uom='kWh',
                    readings=readings)
output = m.output_csv(file_path='output.csv')

Will output:

100,NEM12,201701010101,,123
200,123,E1B1B2,,E1,,,kWh,30,
300,20040418,10.1,11.2,12.3,13.4,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,V,,,,
400,1,1,A,79,Power Outage Alarm
400,2,48,A,,
900

Alternatively, save as a compressed csv in a zip file.

output = m.output_zip(file_path='output.zip')

From Polars DataFrame

If you create a polars DataFrame, for example:

from datetime import datetime, timedelta
from nemwriter import NEM12
from random import randrange
import polars as pl

num_intervals = 288
timestamps = [
    datetime(2004, 4, 1) + timedelta(minutes=5 * x)
    for x in range(1, num_intervals + 1)
]
e1 = [randrange(1, 10) for x in range(1, num_intervals + 1)]
e2 = [randrange(1, 5) for x in range(1, num_intervals + 1)]
df = pl.DataFrame({
    "t_end": timestamps,
    "E1": e1,
    "E2": e2,
})
print(df)
                     E1  E2
2004-04-01 00:05:00   2   3
2004-04-01 00:10:00   8   3
2004-04-01 00:15:00   7   2
2004-04-01 00:20:00   4   3
2004-04-01 00:25:00   3   4
...                  ..  ..
2004-04-01 23:40:00   9   2
2004-04-01 23:45:00   1   1
2004-04-01 23:50:00   6   2
2004-04-01 23:55:00   7   1
2004-04-01 00:00:00   4   2

You can easily output the dataframe to a NEM12 file:

m = NEM12(to_participant='123')
m.add_dataframe(nmi='123', df=df, uoms={'E1': 'kWh', 'E2': 'kWh'})
output = m.output_csv(file_path='output.csv')

If your DataFrame has a Quality and EventDesc column, they will also be handled appropriately.

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

nemwriter-0.6.0.tar.gz (52.9 kB view details)

Uploaded Source

Built Distribution

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

nemwriter-0.6.0-py3-none-any.whl (8.7 kB view details)

Uploaded Python 3

File details

Details for the file nemwriter-0.6.0.tar.gz.

File metadata

  • Download URL: nemwriter-0.6.0.tar.gz
  • Upload date:
  • Size: 52.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for nemwriter-0.6.0.tar.gz
Algorithm Hash digest
SHA256 9d09eb1740de39ce01433acf6448524d031579bb915158a8e23955adec8ec664
MD5 14109b1807f47278e288942ce07bd1b1
BLAKE2b-256 90a34c439c38dbd1c43ba46c8a8b855da6a42ae745fd4ba5abb0a4930a0f0a03

See more details on using hashes here.

File details

Details for the file nemwriter-0.6.0-py3-none-any.whl.

File metadata

  • Download URL: nemwriter-0.6.0-py3-none-any.whl
  • Upload date:
  • Size: 8.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for nemwriter-0.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 4ec309a507d34afcdcdd214ba1ff962ad9b8e66f72f76a18d5a47aca5e0623b5
MD5 59c88327423a93aa12a41ee8b11c4c86
BLAKE2b-256 f2a8b3bbc8ae0d274e6a6b54572a6915c97c8334cddf150e65cc225c5e719307

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