Zum Hauptinhalt springen

Stromtarife

Indem du Stromtarife für Netzbezug, Einspeisung und CO₂-Intensität konfigurierst kann evcc deine Ersparnis berechnen und Ladevorgänge automatisch auf günstige Zeiten verschieben.

Fester Strompreis

Der einfachste Fall sind feste Werte für Netzbezug (grid) und Einspeisung (feedin).

tariffs:
currency: EUR # (default EUR)
grid:
type: fixed
price: 0.294 # EUR/kWh
feedin:
type: fixed
price: 0.08 # EUR/kWh
co2:
...

Zeitabhängiger Strompreis

Stromtarife mit festen zeitabhängigen Preisen können ebenfalls definiert werden.

tariffs:
grid:
type: fixed
price: 0.294 # EUR/kWh (default)
zones:
- days: Mo-Fr
hours: 2-5
price: 0.2 # EUR/kWh
- days: Sa,So
price: 0.15 # EUR/kWh

Unter zones kann eine Liste von Preiszonen definiert werden. Der Geltungszeitraum wird durch days und/oder hours definiert. Ist für einen Zeitpunkt keine Preiszone definiert, wird der Standardpreis verwendet.

Der Befehl evcc tariff zeigt die Preisliste der kommenden Stunden an.

$ ./evcc tariff

grid:
From To Price/Cost
2026-05-03 00:00:00 2026-05-03 01:00:00 0.399
...

feedin:
From To Price/Cost
2026-05-03 00:00:00 2026-05-03 01:00:00 0.080
...

Börsenstrompreise

Du hast einen Vertrag der nach Börsenpreisen berechnet wird? Für viele Anbieter haben wir eine eigene Schnittstelle angebunden (z.B. Awattar oder Tibber). Die Liste aller verfügbaren Anbieter findest du im Abschnitt Dynamischer Strompreis.

Gebühren und Steuern

Falls dein Anbieter nicht dabei ist, kannst du deinen Tarif auf Basis der Day-Ahead-Preise der europäischen Strombörse selbst berechnen. Die Energy-Charts API vom Fraunhofer ISE liefert aktuelle und prognostizierte Preise. Diese werden von fast allen Anbietern als Grundlage für die Berechnung ihrer Energiepreise verwendet.

tariffs:
grid:
type: template
template: energy-charts-api
bzn: DE-LU # Gebotszone, siehe https://api.energy-charts.info/#/prices/day_ahead_price_price_get
charges: 0.22 # Fester Aufschlag pro kWh (z.B. 20ct Netzentgelt, 2ct Gebühren)
tax: 0.19 # Prozentualer Aufschlag (z.B. 19% MwSt.)

Die Schnittstelle liefert die Börsenpreise in Euro ohne lokale Gebühren oder Steuern. Mit den Parametern charges und tax kannst du einen zusätzlichen festen und prozentualen Aufschlag pro kWh definieren. Die genauen Werte kannst du deinem Vertrag entnehmen.

Eigene Berechnungsformeln

Falls das Modell des festen und prozentualen Aufschlags nicht ausreicht, kannst du eine individuelle Formel definieren. Verwende dafür den formula Parameter.

tariffs:
grid:
type: template
template: energy-charts-api
bzn: DE-LU
charges: 0.22 # Fester Aufschlag pro kWh
tax: 0.19 # Prozentualer Aufschlag
formula: math.Min(0.5, (price + charges) * (1 + tax))

Im obigen Beispiel wird eine Preisobergrenze von 50 ct/kWh definiert. Die Formel wird in Go-Syntax geschrieben. Neben den Werten price, charges und tax steht dir die math-Bibliothek zur Verfügung.

Börsenpreise mit Zeitkomponente

Die Formel wird für den aktuellen Strompreis und jeden Zeitslot in der Prognose ausgeführt. Ist die Berechnung zeitabhängig, kannst du über ts auch auf die Zeit des jeweiligen Slots zugreifen.

tariffs:
grid:
type: template
template: energy-charts-api
bzn: DE-LU
formula: extra := 0.1; if ts.Hour() < 6 || ts.Hour() > 22 { extra = 0.0 }; price + extra

In diesem Beispiel gibt es einen Aufschlag von 10 ct/kWh. In der Zeit von 22:00 Uhr bis 06:00 Uhr wird kein Aufschlag berechnet. Der Fantasie sind hier keine Grenzen gesetzt.

Der formula Mechanismus funktioniert auch für viele andere Datenquellen. Schau dir die Konfigurationsoptionen der jeweiligen Quellen an.

Der CLI Befehl evcc tariff ist hilfreich um die Berechnungsergebnisse zu überprüfen.

CO₂ Vorhersage

Electricity Maps

Commercial API

CO₂-Daten für viele Länder von https://electricitymaps.com/. Der 'Free Personal Tier' beinhaltet leider keine Prognosedaten. Dafür benötigst du einen kommerziellen Account von https://api-portal.electricitymaps.com/. Kostenloser Testmonat verfügbar.

tariffs:
co2:
type: template
template: electricitymaps
uri: https://api-access.electricitymaps.com/2w...1g/ # HTTP(S) Adresse
token:
zone: DE # siehe https://api.electricitymap.org/v3/zones

Free API

CO₂-Daten für viele Länder von https://electricitymaps.com/. Der 'Free Personal Tier' beinhaltet leider keine Prognosedaten. Dafür benötigst du einen kommerziellen Account von https://api-portal.electricitymaps.com/. Kostenloser Testmonat verfügbar.

tariffs:
co2:
type: template
template: electricitymaps-free
token:
zone: DE # siehe https://api.electricitymap.org/v3/zones

Grünstromindex

Regionale Emissionsdaten von https://gruenstromindex.de. Nur für Deutschland verfügbar.

tariffs:
co2:
type: template
template: grünstromindex
zip:
token: # Token für den Zugriff auf die API von https://console.corrently.io/ (optional)

National Grid ESO

Nur für Großbritannien verfügbar.

tariffs:
co2:
type: template
template: ngeso
region: 1 # Ungenauer als die Verwendung eines Postleitzahl. Siehe https://carbon-intensity.github.io/api-definitions/#region-list (optional)
postalcode: SW1 # Postleitzahl z.B. RG41 oder SW1 oder TF8. Nicht die vollständige Postleitzahl, nur die ersten Stellen. (optional)

Dynamischer Strompreis

Eigenes Plugin

Über mit dem Plugin Mechanismus kann eine eigene Tarif-Quelle angebunden werden.

Beispiel: Aktueller Preis via HTTP

tariffs:
grid:
type: custom
price:
source: http
uri: https://example.com/api/price

Der vom Endpunkt zurückgegebene Wert wird als Netzbezugspreis verwendet.

Beispiel: Vorhersagen via HTTP

tariffs:
grid:
type: custom
forecast:
source: http
uri: https://api.allinpower.nl/troodon/api/p/spot_market/prices/?product_type=ELK
jq: '[.timestamps, .prices] | transpose | map({ "start": (.[0] | strptime("%Y-%m-%dT%H:%M:%S.%f%z") | strftime("%Y-%m-%dT%H:%M:%SZ")), "end": (.[0] | strptime("%Y-%m-%dT%H:%M:%S.%f%z") | mktime + 3600 | strftime("%Y-%m-%dT%H:%M:%SZ")), "price": .[1] }) | tostring'

Das Plugin muss eine JSON-Struktur zurückgeben, welches eine Liste von Zeiträumen und Preisen enthält. Die Datumsfelder müssen in der Form YYYY-MM-DDTHH:MM:SSZ und der Preis in der korrekten Währungseinheit (bspw. EUR) angegeben werden. Siehe nachfolgendes Beispiel:

[
{ "start": "2025-01-01T00:00:00Z", "end": "2025-01-01T01:00:00Z", "price": 25.0 },
{ "start": "2025-01-01T01:00:00Z", "end": "2025-01-01T02:00:00Z", "price": 30.0 },
]

Das Plugin wird einmal pro Stunde aktualisiert.

Amber Electric

Nur für Australien verfügbar.

tariffs:
grid:
type: template
template: amber
token: # optional
siteid: # optional
channel: # optional

Awattar

Nur für Deutschland und Österreich verfügbar.

tariffs:
grid:
type: template
template: awattar
region: AT # optional

Energinet

Nur für Dänemark verfügbar.

tariffs:
grid:
type: template
template: energinet
region: dk1 # optional

Enever

Nur für Niederlande verfügbar.

tariffs:
grid:
type: template
template: enever
token:
provider:

ENTSO-E

Day-ahead-Preise für den europäischen Strommarkt. Siehe https://transparency.entsoe.eu für weitere Informationen. Basis für viele dynamische Tarife.

tariffs:
grid:
type: template
template: entsoe
securitytoken: # Registrierung und anschließende Helpdesk-Anfrage erforderlich. Details zum Ablauf gibts hier https://transparency.entsoe.eu/content/static_content/Static%20content/web%20api/Guide.html#_authentication_and_authorisation (optional)
domain: BZN|DE-LU # siehe https://transparency.entsoe.eu/content/static_content/Static%20content/web%20api/Guide.html#_areas (optional)

Fraunhofer ISE

Day-ahead Energiepreise (je kWh) an der Börse. Kann ohne vorherige Anmeldung auf https://api.energy-charts.info/ abgerufen werden. Nutzbar u.a. für dynamische Stromtarife, wo der Anbieter bis dato auf der Kundenschnittstelle noch kein Preis-Vorhersagen anbietet.

tariffs:
grid:
type: template
template: energy-charts-api
bzn: DE-LU # Gebotszonen - https://api.energy-charts.info/#/prices/day_ahead_price_price_get

Groupe E Vario Plus

Nur für die Schweiz verfügbar.

tariffs:
grid:
type: template
template: groupe-e

Nordpool spot prices

Nordpool Spot Preise im Day-Ahead-Markt für alle Märkte in der Nordpool-Region.

tariffs:
grid:
type: template
template: nordpool
region: GER # optional
currency: EUR # optional

Octopus Energy

API

Den API-Key bekommst du im Octopus Portal https://octopus.energy/dashboard/new/accounts/personal-details/api-access

tariffs:
grid:
type: template
template: octopus-api
apiKey: # Octopus Energy API Key.

Product Code

tariffs:
grid:
type: template
template: octopus-productcode
productCode: AGILE-FLEX-22-11-25 # Der Tarifcode für Ihren Energievertrag. Stellen Sie sicher, dass dieser auf Ihren Importtarifcode eingestellt ist.
region: # Die DNO-Region, in der Sie sich befinden. Weitere Informationen: https://www.energy-stats.uk/dno-region-codes-explained/

Ostrom

Erzeuge einen 'Production Client' im Ostrom-Entwicklerportal: https://developer.ostrom-api.io/

tariffs:
grid:
type: template
template: ostrom
clientid: 476c477d8a039529478ebd690d35ddd80e3308ffc49b59c65b142321aee963a4
clientsecret: 476c477d8a039529478ebd690d35ddd80e3308ffc49b59c65b142321aee963a4476c477d8a039529478ebd690d35ddd80e3308ffc49b59c65b142321aee963a4a
contract: 100523456 # Nur erforderlich, wenn mehrere Verträge unter einem Benutzer existieren (optional)

PUN Orario

Preisdaten von https://www.mercatoelettrico.org/it/. Wird oft zur Einspeisung ins Netz verwendet. Nur für Italien verfügbar.

tariffs:
grid:
type: template
template: pun

SmartEnergy smartCONTROL

Nur für Österreich verfügbar.

tariffs:
grid:
type: template
template: smartenergy

Spotty Energie

Nur für Österreich verfügbar.

tariffs:
grid:
type: template
template: spottyenergy
contractid: ffffffff-4444-6666-2222-aaaaaabbbbbb # Die Vertragsnummer bekommst du im Kundenportal https://i.spottyenergie.at/
pricetype: CONSUMPTION # Preistyp, entweder Börsenpreis, Verbrauchspreis oder Einspeisevergütung (falls vereinbart), siehe https://www.spottyenergie.at/blog/energie-smart-produzieren

Tibber

Hol dir deinen API-Token aus dem Tibber-Entwicklerportal: https://developer.tibber.com/

tariffs:
grid:
type: template
template: tibber
token: 476c477d8a039529478ebd690d35ddd80e3308ffc49b59c65b142321aee963a4
homeid: cc83e83e-8cbf-4595-9bf7-c3cf192f7d9c # Nur erforderlich, wenn du mehrere Häuser in deinem Tibber-Konto hast. (optional)