Skip to content

clara-lupa/photovoltaik

Repository files navigation

Photovoltaik

Photovoltaik is a read-only web API that provides reference data on specific energy yields of photovoltaik systems in Germany depending on their location and capacity. Thereby it enables photovoltaik operators to compare the generated energy yields with the expected yields for their PV system.

Prerequisites

  • Python3

Installing Photovoltaik

Start with cloning this repository and change to the project directory:

$ git clone https://github.com/clara-lupa/photovoltaik.git
$ cd photovoltaik

Then create a virtual environment to install the dependencies and activate this virtual envrionment:

$ python3 -m venv env  # creates virtual environment, install venv if necessary
$ source env/bin/activate

If you have not installed venv yet, you will be asked to install it. Follow the instructions in the terminal in order to do so, and then run the above commands again. You should see (env) in front of your terminal's prompt if you have activated the virtual environment successfully.

Install the depencies:

(env)$ pip install -r requirements.txt

Create a hidden file for environment variables with then name .env in the project's root directory (i.e. in the directory where the file manage.py is)

(env)$ touch .env

In the .env file, you need to define and export your secret key and set the value for debug. This is done by adding the following lines to the .env file:

export SECRET_KEY="<your own secret key>"
export DEBUG_VALUE="True"

You can generate a secret key for example by using the python3 interpreter with the following commands in your terminal:

(env)$ python3 # starts python3 interpreter
>>> import secrets
>>> secrets.token_hex(24)

Copy-paste the terminal's output in the .env file. Then close the python3 interpreter:

>>> exit() # leave python3 interpreter

The next step is loading the initial data from pv_yields.json, which is a .json file storing the specific yield data for all german federal states for the year 2019 data source. Therefore type in the terminal:

(env)$ python manage.py loaddata pv_yields.json

You should see a message in the terminal stating that 16 objects have been successfully installed. The installation is finished now. You can run a local server to to test the API now:

(env)$ python manage.py runserver

Navigate to http://localhost:8000/api/pv_yield?state=by using a browser, the curl command or an application like Postman. You should receive a json like this as response:

{"yield": 1140, "state": "by"}

For further details on how to use the app see the next section and use http://localhost:8000 as <Base_URL>!

Using Photovoltaik

In order to use Photovoltaik, you can either install and run the API on your local machine (following the instructions from the previous section and use http://localhost:8000 as <Base_URL> in the following instructions) or you can access an already deployed version, using https://cw-photovoltaik.herokuapp.com as <BASE_URL> in the following instructions. The API responds to two different types of requests, which will be explained below.

1. Accessing the yield of a federal state

When given a german federal state, the API provides the specific yield of that federal state in the year 2019. Therefore, make a request with the format

<BASE_URL>/api/pv_yield?state=<STATE_CODE>

State code is supposed to be replaced by a valid two-letter code for one of the german federal states (click here for more details about the german federal state codes). E.g.in order to access the value for Bavaria (BY), the request is:

http://localhost:8000/api/pv_yield?state=by # for the local version, or
https://cw-photovoltaik.herokuapp.com/api/pv_yield?state=by # for the deployed version

The response will look be a json containing the state, which was given in the request, and its specific yield in kWh/kWp/year. For the example above, it should look like this:

{"yield": 1140, "state": "by"}

2. Accessing the yield for a photovoltaik system, given its locations postcode and its capacity

When given a german postcode and the system's capacity, the API provides a yield value of a photovoltaik system with the given capacity and location. Therefore the request follows the pattern

<BASE_URL>/api/pv_yield?plz=<POST_CODE>&capacity=<CAPACITY>

Here, <POST_CODE> is a placeholder for a valid german postcode (5 digits) and <CAPACITY> should be replaced by the system's installed capacity in kWp. If you would like to get a reference yield for a system with a capacity of 10kWp, placed in 07349 Lehesten (Germany), you would want to make the request

http://localhost:8000/api/pv_yield?plz=07349&capacity=10 # for the local version, or
https://cw-photovoltaik.herokuapp.com/api/pv_yield?plz=07349&capacity=10 # for the deployed version

The response will be a json, containing the systems yield in kWh/year for the given location and capacity, and the federal state's code, where the given postcode is part of:

{"yield": 10900, "state": "th"}

License

GNU General Public License

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages