| Name | nrgpy JSON | 
| Version | 2.3.12  JSON | 
|  | download | 
| home_page | None | 
| Summary | library for handling NRG Systems data files | 
            | upload_time | 2025-07-30 16:43:37 | 
            | maintainer | None | 
            
            | docs_url | None | 
            | author | None | 
            
            | requires_python | >=3.8 | 
            
            
            | license | Copyright (c) 2023 NRG Systems, Inc.
        
        Permission is hereby granted, free of charge, to any person obtaining a copy
        of this software and associated documentation files (the "Software"), to deal
        in the Software without restriction, including without limitation the rights
        to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
        copies of the Software, and to permit persons to whom the Software is
        furnished to do so, subject to the following conditions:
        
        The above copyright notice and this permission notice shall be included in all
        copies or substantial portions of the Software.
        
        THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
        IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
        FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
        AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
        LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
        OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
        SOFTWARE. | 
            | keywords | nrg
                
                     nrg systems
                
                     symphonie
                
                     symphonieplus
                
                     symphonieplus3
                
                     symphoniepro
                
                     logr
                
                     data
                
                     wind
                
                     solar
                
                     remote sensor
                
                     rsd
                
                     lidar
                
                     spidar | 
            | VCS |  | 
            | bugtrack_url |  | 
            | requirements | No requirements were recorded. | 
            
| Travis-CI | No Travis. | 
            | coveralls test coverage | No coveralls. | 
        
        
            
            #  nrgpy

**nrgpy** is the Python package for processing NRG Data Files
|                    |                                            |
| ------------------ | ------------------------------------------ |
| Website and source | <https://github.com/nrgpy/nrgpy>           |
| Documentation      | <https://nrgpy.github.io/nrgpy/index.html> |
| IEA Task 43 Parser | <https://github.com/nrgpy/nrg-parser>      |
| Support            |  <support@nrgsystems.com>                    |
It provides tools for:
- Converting binary ".rld" and ".rwd" files to text format
  - using locally installed SymphoniePRO Desktop Software and Symphonie Data Retriever
  - using NRG Cloud API (compatible with Linux!) *(SymphoniePRO only at this time)
- Reading Symphonie text exports, LOGR dat, and Spidar zip/csv files into Pandas dataframes
- Timestamp adjustment (of text files)
- Simple quality checks on data
***
## Contributing
See our [Contributing guidelines](./CONTRIBUTING.md) for how to be a part of this project.
## Installation
    pip install nrgpy
## Log and token files
Log files and NRG Cloud token files will be generated when using the app. These files can be found
in your '''home''' directory:
### Windows
```C:\Users\{username}\.nrgpy\```
### Linux/Mac
```/home/{username}/.nrgpy/```
## Examples
For more examples see the Documentation:  <https://nrgpy.github.io/nrgpy/index.html>
### RLD files
#### Convert a folder of RLD files to Text with SymphoniePRO Desktop Software
```python
import nrgpy
date_filter = '2018-10' # filter on any text in the filenames
text_folder_name = 'text_outputs/'
converter = nrgpy.local_rld(rld_dir='', out_dir=text_folder_name, file_filter=date_filter)
converter.convert()
```
#### Convert a folder of RLD files to Text with NRG Cloud Convert API
```python
import nrgpy
file_filter = "000110"
rld_directory = "rlds"
client_id = "https://cloud.nrgsystems.com/data-manager/api-setup"
client_secret = ""
converter = nrgpy.cloud_convert(
    file_filter=file_filter, 
    rld_dir=rld_directory, 
    client_id=client_id,
    client_secret=client_secret,
    start_date="2019-11-01",
    end_date="2019-11-30",
)
converter.process()
```
#### Convert a single RLD file to Text with NRG Cloud API
```python
import nrgpy
filename = "path/to/rld"
txt_dir = "path/to/txt/"
client_id = "https://cloud.nrgsystems.com/data-manager/api-setup"
client_secret = ""
converter = nrgpy.CloudConvert(
    filename=filename, 
    client_id=client_id,
    client_secret=client_secret,
)
```
#### Read files
```python
file_filter = "000110"
import nrgpy
reader = nrgpy.SymProTextRead()
reader.concat_txt(
    txt_dir=text_folder_name, 
    file_filter=file_filter, 
    start_date="2019-11-01",
    end_date="2019-11-30",
)
```
### RWD files
#### Convert a folder of RWD files to Text with Symphonie Data Retriever
```python
import nrgpy
file_filter = '0434201902' # for Feb 2019 files from site 0434
rwd_directory = 'C:/Users/[user]/rwd/'
out_directory = 'C:/Users/[user]/txt/'
converter = nrgpy.local_rwd(file_filter=file_filter, rwd_dir=rwd_directory, out_dir=out_directory)
converter.convert()
```
#### Convert a folder of RWD files to Text with Symphonie Data Retriever _on Linux_
```python
import nrgpy
rwd_directory = '/home/user/datafiles/rwd'
out_directory = '/home/user/datafiles/txt'
wine_directory = '/home/user/prefix32/drive_c/' # path to wine's "C:\" drive
converter = nrgpy.local_rwd(
                file_filter=file_filter, 
                rwd_dir=rwd_directory, 
                out_dir=out_directory,
                wine_folder=wine_directory,
                use_site_file=False # set to True to use site files
            )
converter.convert()
```
You can also convert a single file with SDR, and save it in the same directory:
```python
import nrgpy
filename = '/path/to/file'
converter = nrgpy.local_rwd(filename=filename)
```
#### Read TXT files exported from RWD files
```python
import nrgpy
dt = 'rwd'
txt_file = '/path/to/file.txt'
reader = nrgpy.read_text_data(data_type=dt, filename=txt_file)
```
or concatenate a whole lot of files:
```python
dt = 'rwd'
txt_dir = '/path/to/text/files'
file_filter = 'text_in_filenames_you_want'
reader = nrgpy.read_text_data(data_type=dt, txt_dir=txt_dir, file_filter=file_filter)
reader.concat()
```
### Spidar files
Spidar Vertical Profiler remote sensors generate archived csv data files in a Zip format.
These can be read directly into the spidar_txt_read method. See the docstring in
spidar_txt.py for more information.
Eg.
``` python
In [1]: import nrgpy
In [2]: fname = "/spidar/1922AG7777_CAG70-SPPP-LPPP_NRG1_AVGWND_2019-07-07_1.zip"                            
In [3]: reader = nrgpy.SpidarRead(filename=fname)                                                                              
In [4]: reader.heights                                                                                                         
Out[4]: [40, 60, 80, 90, 100, 120, 130, 160, 180, 200]
In [5]: reader.data                                                                                                            
Out[5]: 
                     pressure[mmHg]  temperature[C]  ...  dir_200_std[Deg]  wind_measure_200_quality[%]
Timestamp                                            ...                                               
2019-07-06 23:40:00          749.66           24.13  ...             28.77                           68
2019-07-06 23:50:00          749.63           24.08  ...             14.31                            0
2019-07-07 00:00:00          749.64           23.99  ...             20.59                            0
...
```
            
         
        Raw data
        
            {
    "_id": null,
    "home_page": null,
    "name": "nrgpy",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.8",
    "maintainer_email": "David Carlson <davec.vt@gmail.com>",
    "keywords": "nrg, nrg systems, symphonie, symphonieplus, symphonieplus3, symphoniepro, logr, data, wind, solar, remote sensor, rsd, lidar, spidar",
    "author": null,
    "author_email": "David Carlson <drc@nrgsystems.com>, Natalie Babij <natalie@chickadeemail.com>, NRG Technical Services <support@nrgsystems.com>",
    "download_url": null,
    "platform": null,
    "description": "#  nrgpy\r\n\r\n\r\n\r\n**nrgpy** is the Python package for processing NRG Data Files\r\n\r\n|                    |                                            |\r\n| ------------------ | ------------------------------------------ |\r\n| Website and source | <https://github.com/nrgpy/nrgpy>           |\r\n| Documentation      | <https://nrgpy.github.io/nrgpy/index.html> |\r\n| IEA Task 43 Parser | <https://github.com/nrgpy/nrg-parser>      |\r\n| Support            |  <support@nrgsystems.com>                    |\r\n\r\nIt provides tools for:\r\n\r\n- Converting binary \".rld\" and \".rwd\" files to text format\r\n  - using locally installed SymphoniePRO Desktop Software and Symphonie Data Retriever\r\n  - using NRG Cloud API (compatible with Linux!) *(SymphoniePRO only at this time)\r\n- Reading Symphonie text exports, LOGR dat, and Spidar zip/csv files into Pandas dataframes\r\n- Timestamp adjustment (of text files)\r\n- Simple quality checks on data\r\n\r\n***\r\n\r\n## Contributing\r\n\r\nSee our [Contributing guidelines](./CONTRIBUTING.md) for how to be a part of this project.\r\n\r\n## Installation\r\n\r\n    pip install nrgpy\r\n\r\n## Log and token files\r\n\r\nLog files and NRG Cloud token files will be generated when using the app. These files can be found\r\nin your '''home''' directory:\r\n\r\n### Windows\r\n\r\n```C:\\Users\\{username}\\.nrgpy\\```\r\n\r\n### Linux/Mac\r\n\r\n```/home/{username}/.nrgpy/```\r\n\r\n## Examples\r\n\r\nFor more examples see the Documentation:  <https://nrgpy.github.io/nrgpy/index.html>\r\n\r\n### RLD files\r\n\r\n#### Convert a folder of RLD files to Text with SymphoniePRO Desktop Software\r\n\r\n```python\r\nimport nrgpy\r\ndate_filter = '2018-10' # filter on any text in the filenames\r\ntext_folder_name = 'text_outputs/'\r\nconverter = nrgpy.local_rld(rld_dir='', out_dir=text_folder_name, file_filter=date_filter)\r\nconverter.convert()\r\n```\r\n\r\n#### Convert a folder of RLD files to Text with NRG Cloud Convert API\r\n\r\n```python\r\nimport nrgpy\r\nfile_filter = \"000110\"\r\nrld_directory = \"rlds\"\r\nclient_id = \"https://cloud.nrgsystems.com/data-manager/api-setup\"\r\nclient_secret = \"\"\r\nconverter = nrgpy.cloud_convert(\r\n    file_filter=file_filter, \r\n    rld_dir=rld_directory, \r\n    client_id=client_id,\r\n    client_secret=client_secret,\r\n    start_date=\"2019-11-01\",\r\n    end_date=\"2019-11-30\",\r\n)\r\nconverter.process()\r\n```\r\n\r\n#### Convert a single RLD file to Text with NRG Cloud API\r\n\r\n```python\r\nimport nrgpy\r\nfilename = \"path/to/rld\"\r\ntxt_dir = \"path/to/txt/\"\r\nclient_id = \"https://cloud.nrgsystems.com/data-manager/api-setup\"\r\nclient_secret = \"\"\r\nconverter = nrgpy.CloudConvert(\r\n    filename=filename, \r\n    client_id=client_id,\r\n    client_secret=client_secret,\r\n)\r\n```\r\n\r\n#### Read files\r\n\r\n```python\r\nfile_filter = \"000110\"\r\nimport nrgpy\r\n\r\nreader = nrgpy.SymProTextRead()\r\nreader.concat_txt(\r\n    txt_dir=text_folder_name, \r\n    file_filter=file_filter, \r\n    start_date=\"2019-11-01\",\r\n    end_date=\"2019-11-30\",\r\n)\r\n```\r\n\r\n### RWD files\r\n\r\n#### Convert a folder of RWD files to Text with Symphonie Data Retriever\r\n\r\n```python\r\nimport nrgpy\r\n\r\nfile_filter = '0434201902' # for Feb 2019 files from site 0434\r\nrwd_directory = 'C:/Users/[user]/rwd/'\r\nout_directory = 'C:/Users/[user]/txt/'\r\n\r\nconverter = nrgpy.local_rwd(file_filter=file_filter, rwd_dir=rwd_directory, out_dir=out_directory)\r\nconverter.convert()\r\n```\r\n\r\n#### Convert a folder of RWD files to Text with Symphonie Data Retriever _on Linux_\r\n\r\n```python\r\nimport nrgpy\r\n\r\nrwd_directory = '/home/user/datafiles/rwd'\r\nout_directory = '/home/user/datafiles/txt'\r\nwine_directory = '/home/user/prefix32/drive_c/' # path to wine's \"C:\\\" drive\r\n\r\n\r\nconverter = nrgpy.local_rwd(\r\n                file_filter=file_filter, \r\n                rwd_dir=rwd_directory, \r\n                out_dir=out_directory,\r\n                wine_folder=wine_directory,\r\n                use_site_file=False # set to True to use site files\r\n            )\r\nconverter.convert()\r\n```\r\n\r\nYou can also convert a single file with SDR, and save it in the same directory:\r\n\r\n```python\r\nimport nrgpy\r\n\r\nfilename = '/path/to/file'\r\nconverter = nrgpy.local_rwd(filename=filename)\r\n```\r\n\r\n#### Read TXT files exported from RWD files\r\n\r\n```python\r\nimport nrgpy\r\n\r\ndt = 'rwd'\r\ntxt_file = '/path/to/file.txt'\r\nreader = nrgpy.read_text_data(data_type=dt, filename=txt_file)\r\n```\r\n\r\nor concatenate a whole lot of files:\r\n\r\n```python\r\ndt = 'rwd'\r\ntxt_dir = '/path/to/text/files'\r\nfile_filter = 'text_in_filenames_you_want'\r\nreader = nrgpy.read_text_data(data_type=dt, txt_dir=txt_dir, file_filter=file_filter)\r\nreader.concat()\r\n```\r\n\r\n### Spidar files\r\n\r\nSpidar Vertical Profiler remote sensors generate archived csv data files in a Zip format.\r\n\r\nThese can be read directly into the spidar_txt_read method. See the docstring in\r\nspidar_txt.py for more information.\r\n\r\nEg.\r\n\r\n``` python\r\nIn [1]: import nrgpy\r\n\r\nIn [2]: fname = \"/spidar/1922AG7777_CAG70-SPPP-LPPP_NRG1_AVGWND_2019-07-07_1.zip\"                            \r\n\r\nIn [3]: reader = nrgpy.SpidarRead(filename=fname)                                                                              \r\n\r\nIn [4]: reader.heights                                                                                                         \r\nOut[4]: [40, 60, 80, 90, 100, 120, 130, 160, 180, 200]\r\n\r\nIn [5]: reader.data                                                                                                            \r\nOut[5]: \r\n                     pressure[mmHg]  temperature[C]  ...  dir_200_std[Deg]  wind_measure_200_quality[%]\r\nTimestamp                                            ...                                               \r\n2019-07-06 23:40:00          749.66           24.13  ...             28.77                           68\r\n2019-07-06 23:50:00          749.63           24.08  ...             14.31                            0\r\n2019-07-07 00:00:00          749.64           23.99  ...             20.59                            0\r\n...\r\n```\r\n",
    "bugtrack_url": null,
    "license": "Copyright (c) 2023 NRG Systems, Inc.\r\n        \r\n        Permission is hereby granted, free of charge, to any person obtaining a copy\r\n        of this software and associated documentation files (the \"Software\"), to deal\r\n        in the Software without restriction, including without limitation the rights\r\n        to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\r\n        copies of the Software, and to permit persons to whom the Software is\r\n        furnished to do so, subject to the following conditions:\r\n        \r\n        The above copyright notice and this permission notice shall be included in all\r\n        copies or substantial portions of the Software.\r\n        \r\n        THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\r\n        IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\r\n        FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\r\n        AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\r\n        LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\r\n        OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\r\n        SOFTWARE.\r\n        ",
    "summary": "library for handling NRG Systems data files",
    "version": "2.3.12",
    "project_urls": {
        "Documentation": "https://nrgpy.github.io/nrgpy/index.html",
        "Repository": "https://github.com/nrgpy/nrgpy"
    },
    "split_keywords": [
        "nrg",
        " nrg systems",
        " symphonie",
        " symphonieplus",
        " symphonieplus3",
        " symphoniepro",
        " logr",
        " data",
        " wind",
        " solar",
        " remote sensor",
        " rsd",
        " lidar",
        " spidar"
    ],
    "urls": [
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "dbf56d8079c1d042f0f96f86ec01eea9db2b865c682ef012a082ac5adf28db17",
                "md5": "2003c61b393c71221a2f0b50ff6b79d9",
                "sha256": "0ce54ae8800ab9ee7cb53fd6015587b7fe77fd088bf37bb653ea91057216e86f"
            },
            "downloads": -1,
            "filename": "nrgpy-2.3.12-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "2003c61b393c71221a2f0b50ff6b79d9",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.8",
            "size": 75923,
            "upload_time": "2025-07-30T16:43:37",
            "upload_time_iso_8601": "2025-07-30T16:43:37.662221Z",
            "url": "https://files.pythonhosted.org/packages/db/f5/6d8079c1d042f0f96f86ec01eea9db2b865c682ef012a082ac5adf28db17/nrgpy-2.3.12-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-07-30 16:43:37",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "nrgpy",
    "github_project": "nrgpy",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "nrgpy"
}