suchen
HeimBackend-EntwicklungPython-TutorialPython Django Financial Trading Dashboard – Integration von AnyChart JS-Charts

Wir freuen uns, einen hilfreichen Artikel zu EODHD-APIs zu teilen, in dem Michael Whittle, ein erfahrener Entwickler und Top-Medium-Autor, zeigt, wie er unsere JavaScript-Charting-Bibliothek in sein Python-Django-basiertes Handels-Dashboard integriert hat.

Er bespricht insbesondere seine Erfahrungen bei der Migration einer Baumkarte von D3.js zu AnyChart und erklärt, warum er sich für unsere Lösung zur Implementierung eines Aktiendiagramms entschieden hat, wobei er den intuitiven Code und die erweiterte Funktionalität hervorhebt.

Lesen Sie weiter, um zu erfahren, wie Sie Ihre Finanzdatenvisualisierungen in Python-Django-Webanwendungen mit AnyChart JS Charts verbessern können.


Python Django Financial Trading Dashboard — Integrating AnyChart JS Charts

Dieser Artikel baut auf den beiden vorherigen Artikeln der Serie auf: „Erstellen eines Finanzhandels-Dashboards mit Python Django“ und „Verbesserung des Finanzhandels-Dashboards mit Python Django“.

Zuerst habe ich die Treemap auf der Landingpage mit der D3.js-Bibliothek erstellt. Obwohl es gut funktionierte, wollte ich andere Diagrammoptionen erkunden und habe daher sowohl Chart.js als auch AnyChart evaluiert. Letztendlich habe ich beschlossen, die Treemap von D3.js nach AnyChart zu migrieren. Obwohl das visuelle Erscheinungsbild der Diagramme recht ähnlich ist, fand ich den Code von AnyChart deutlich intuitiver und leichter zu verstehen. Darüber hinaus finde ich persönlich, dass die AnyChart-Baumkarte etwas mehr Funktionalität bietet und ausgefeilter aussieht. Allerdings gefiel mir auch die Ästhetik von Chart.js, was nach wie vor eine praktikable Option ist.

Im vorherigen Artikel habe ich eine Seite erstellt, auf der die historischen Daten eines Marktes angezeigt werden, die mithilfe einer Bootstrap-Datentabelle übersichtlich dargestellt werden. Für diesen Artikel wollte ich über der Tabelle ein ansprechendes Aktiendiagramm einfügen. Ich habe noch einmal über die drei Diagrammbibliotheken nachgedacht, war aber besonders beeindruckt von der Art und Weise, wie AnyChart die Daten präsentierte, und von der Funktionalität, die es bot. In diesem Artikel wird erläutert, wie dies erreicht wurde.

Python Django Financial Trading Dashboard — Integrating AnyChart JS Charts

Endlich habe ich eine weitere nützliche Funktion von Bootstrap entdeckt. Im vorherigen Artikel habe ich gezeigt, wie man eine Schaltfläche „Nach Excel exportieren“ hinzufügt. Ebenso können Sie mit nur einer Codezeile auch eine Schaltfläche „Drucken“ hinzufügen. Diese Funktion übernimmt die Daten aus der Bootstrap-Tabelle und präsentiert sie in einem druckfreundlichen Format.

Python Django Financial Trading Dashboard — Integrating AnyChart JS Charts

Schneller Sprung:
  1. Aktualisieren der Ansicht
  2. Aktualisieren der Vorlage – index.html
  3. Aktualisieren der Vorlage – Historical_data.html
  4. Zusammenfassung
  5. Nächste Schritte

Aktualisieren der Ansicht

Ich musste nur eine Änderung an einer Ansicht vornehmen, damit das Aktiendiagramm mit historischen Daten funktioniert.

def fetch_historical_data(request, market, interval):
  now = datetime.now()

  if interval in ["m", "w", "d"]:
    end_date = now.date().isoformat()
    start_date = (now - timedelta(days=300)).date().isoformat()
  else:
    end_date = now.strftime("%Y-%m-%dT%H:%M")
    start_date = (now - timedelta(hours=300)).strftime("%Y-%m-%dT%H:%M")

  start_date = request.GET.get("from", start_date)
  end_date = request.GET.get("to", end_date)

  def parse_datetime(dt_str):
    try:
      return datetime.strptime(dt_str, "%Y-%m-%dT%H:%M:%S")
    except ValueError:
      try:
        return datetime.strptime(dt_str, "%Y-%m-%dT%H:%M")
      except ValueError:
        return datetime.strptime(dt_str, "%Y-%m-%d")

  start_date_parsed = parse_datetime(start_date)
  end_date_parsed = parse_datetime(end_date)

  if interval in ["m", "w", "d"]:
    start_date = start_date_parsed.strftime("%Y-%m-%d")
    end_date = end_date_parsed.strftime("%Y-%m-%d")
  else:
    start_date_unix = int(start_date_parsed.timestamp())
    end_date_unix = int(end_date_parsed.timestamp())

  endpoint = "eod" if interval in ["m", "w", "d"] else "intraday"
  interval_type = "period" if interval in ["m", "w", "d"] else "interval"

  if interval not in ["m", "w", "d"]:
    url = f"https://eodhd.com/api/{endpoint}/{market}?{interval_type}={interval}&from={start_date_unix}&to={end_date_unix}&api_token={settings.EODHD_API_TOKEN}&fmt=json"
  else:
    url = f"https://eodhd.com/api/{endpoint}/{market}?{interval_type}={interval}&from={start_date}&to={end_date}&api_token={settings.EODHD_API_TOKEN}&fmt=json"

  print(url)
  response = requests.get(url)
  data = response.json()

  def format_unix_timestamp(unix_ts):
    return datetime.utcfromtimestamp(unix_ts).strftime("%Y-%m-%d %H:%M:%S")

  for entry in data:
    if "date" in entry:
      entry["timestamp"] = entry.pop("date")
    elif "datetime" in entry:
      datetime_value = entry.pop("datetime")
      try:
        entry["timestamp"] = format_unix_timestamp(int(datetime_value))
      except ValueError:
        entry["timestamp"] = datetime_value

  if not data or "error" in data:
    data = []

  raw_data = data
  historical_data_json = json.dumps(data)

  return render(
    request,
    "historical/historical_data.html",
    {
      "market": market,
      "interval": interval,
      "historical_data": raw_data,  # Raw Python data for the table
      "historical_data_json": historical_data_json,  # JSON for the script
      "start_date": (
        start_date
        if interval in ["m", "w", "d"]
        else start_date_parsed.strftime("%Y-%m-%dT%H:%M")
      ),
      "end_date": (
        end_date
        if interval in ["m", "w", "d"]
        else end_date_parsed.strftime("%Y-%m-%dT%H:%M")
      ),
    },
  )

Wenn Sie die Ausgabe der Funktion genau beobachten, werden Sie feststellen, dass ich die Daten in zwei Teile aufgeteilt habe. Die erste, „historical_data“, enthält die von der API zurückgegebenen Rohdaten, die für die Bootstrap-Datentabelle verwendet werden. Die zweite, „historical_data_json“, ist eine bereinigte Version der Daten im JSON-Format, die für den AnyChart-Aktienchart erforderlich ist. Es war tatsächlich eine ziemliche Herausforderung, dies zum Laufen zu bringen. Ich wollte zwei Möglichkeiten zur Visualisierung der historischen Daten bereitstellen, aber jede erforderte die Daten in einem anderen Format. Dieser Ansatz erwies sich als effektive Lösung.

Aktualisieren der Vorlage – index.html

Wie ich oben erwähnt habe, verwendete meine erste Treemap die D3.js-Bibliothek. Ich habe sowohl die Chart.js- als auch die AnyChart-Bibliotheken evaluiert. Ich fand die AnyChart-Bibliothek initiativ und sieht viel schöner und ausgefeilter aus. Ich habe den konvertierten Code unten eingefügt.

GOTCHA

Ich bin auf einen der seltsamsten Fehler gestoßen, der mich mehrere Tage lang verwirrt hat. Als ich den Treemap-Code zunächst von D3.js nach AnyChart konvertierte, funktionierte es einwandfrei. Dann verlagerte ich meinen Fokus auf das Aktiendiagramm „Historische Daten“, aber als ich zur AnyChart-Baumkarte zurückkehrte, wurde es nicht richtig gerendert. Obwohl die API Daten für 110 Marktindizes empfing, wurden nur 11 angezeigt.

Um dies zu debuggen, musste ich den Code auf seine einfachsten Komponenten reduzieren. Wie sich herausstellte, hing das „Problem“ mit der Einbeziehung von daily_return als Wert für die Baumkarte zusammen. Ich habe mich für die Verwendung von daily_return anstelle der Anzahl der Bestandteile entschieden, da dadurch ein optisch ansprechenderer Farbverlauf zwischen hohen und niedrigen Werten entsteht. Ich habe jedoch herausgefunden, dass Baumkarten positive Zahlen als Werte benötigen, um korrekt dargestellt zu werden – das ist einfach ihre Funktionsweise.

Als ich es zum ersten Mal zum Laufen brachte, müssen die Marktbedingungen außergewöhnlich gut gewesen sein, da alle täglichen Renditen positiv waren. Als ich den Code ein paar Tage später noch einmal überprüfte, waren einige tägliche Rückgaben negativ, was dazu führte, dass nur 11 Einträge angezeigt wurden.

Um dieses Problem anzugehen, habe ich eine einfache, aber effektive Lösung entwickelt. Ich habe dafür gesorgt, dass der an die Baumkarte übergebene Wert immer absolut (eine positive Zahl) war, und habe diesen Wert aus der Zellenanzeige entfernt. Stattdessen habe ich es zu einem Tooltip hinzugefügt, der beim Bewegen der Maus angezeigt wird. Dadurch konnte die Baumkarte korrekt mit einem angenehmen Farbverlauf gerendert werden, während bei Bedarf immer noch der tatsächliche Wert angezeigt werden konnte.


<kopf>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Marktindizes-Baumkarte</title>

  https://cdn.anychart.com/releases/8.13.0/js/anychart-bundle.min.js
  <link href="https://stackpath.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css" rel="stylesheet">

  <stil>
    Körper {
      Hintergrundfarbe: #343a40;
      Farbe: #ffffff;
    }
    #treemap {
      Breite: 100 %;
      Höhe: 80vh;
      Rand: 0 automatisch;
    }
  


<k>
  <div>



<h3>
  
  
  Aktualisieren der Vorlage – Historical_data.html 
</h3>

<p>Der nächste Teil bestand darin, das AnyChart-Aktiendiagramm über der Bootstrap-Tabelle mit historischen Daten hinzuzufügen. Wie ich oben erwähnt habe, habe ich auch die Schaltfläche „Drucken“ hinzugefügt, was praktisch sein könnte.</p>

<p>Ich fand, dass sowohl Chart.js als auch AnyChart wirklich angenehme, funktionsreiche Grafiken hatten. Ich habe mich für AnyChart entschieden, weil ich die Bibliotheken in der App nicht vermischen wollte, mir aber auch das Aussehen des Diagramms sehr gut gefallen hat.</p>

<p>Was ich wirklich schön finde, ist, dass die Grafik interaktiv ist. Für zusätzliche Informationen können Sie die Datenpunkte schwenken, zoomen und mit der Maus darüber bewegen. Als Einstieg in die Aktie können Sie die Candlesticks auch visuell dargestellt sehen, wie es bei den meisten Handelsanwendungen der Fall ist. Ein grüner Balken, wenn der Schlusskurs höher als der Eröffnungskurs ist, und ein rotes Auto, wenn der Schlusskurs niedriger als der Eröffnungskurs ist.<br>
</p>
<pre class="brush:php;toolbar:false">


<kopf>
  <title>Historische Daten für {{ Market }} ({{ Interval }})</title>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1, Shrink-to-fit=no">

  <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css">
  <link rel="stylesheet" href="https://cdn.datatables.net/1.10.21/css/dataTables.bootstrap4.min.css">
  <link rel="stylesheet" href="https://cdn.datatables.net/buttons/1.7.1/css/buttons.bootstrap4.min.css">

  <stil>
    Körper {
      Hintergrundfarbe: #343a40;
      Farbe: #ffffff;
    }

    .Tisch {
      Hintergrundfarbe: #212529;
    }

    .table th, .table td {
      Farbe: #ffffff;
    }

    .chart-container {
      Rand unten: 20px;
    }

    .dt-buttons .btn {
      Rand rechts: 10px;
    }

    .page-item.active .page-link {
      Z-Index: 3;
      Farbe: #ffffff !important;
      Hintergrundfarbe: #495057 !important;
      Rahmenfarbe: #495057 !important;
    }

    .page-link {
      Farbe: #ffffff !important;
      Hintergrundfarbe: #6c757d !important;
      Rahmenfarbe: #343a40 !important;
    }

    .page-link:hover {
      Farbe: #adb5bd !important;
      Hintergrundfarbe: #5a6268 !important;
      Rahmenfarbe: #343a40 !important;
    }

    .dataTables_wrapper .dataTables_paginate .paginate_button {
      Farbe: #ffffff !important;
      Hintergrundfarbe: #6c757d !important;
      Rand: 1px solide #343a40 !important;
    }

    .dataTables_wrapper .dataTables_paginate .paginate_button:hover {
      Hintergrundfarbe: #5a6268 !important;
      Rand: 1px solide #343a40 !important;
    }

    .dataTables_wrapper .dataTables_paginate .paginate_button.current {
      Farbe: #ffffff !important;
      Hintergrundfarbe: #495057 !important;
      Rand: 1px solide #343a40 !important;
    }

    .dataTables_wrapper .dataTables_paginate .paginate_button.disabled,
    .dataTables_wrapper .dataTables_paginate .paginate_button.disabled:hover {
      Hintergrundfarbe: #6c757d !important;
      Farbe: #ffffff !important;
    }

    .btn-dark {
      Hintergrundfarbe: #6c757d !important;
      Rahmenfarbe: #6c757d !important;
      Farbe: #ffffff !important;
    }

    .btn-dark:hover {
      Hintergrundfarbe: #5a6268 !important;
      Rahmenfarbe: #5a6268 !important;
    }
  


<k>
  <div>



<h3>
  
  
  Zusammenfassung 
</h3>

<p>Ich finde den Code der JavaScript-Diagrammbibliothek von AnyChart einfach zu lesen und zu verstehen. Allerdings wird in den Diagrammen das Wasserzeichen „Testversion“ angezeigt. Durch den Kauf einer Lizenz wird dieses Wasserzeichen entfernt und zusätzlicher Support geboten. Trotzdem hat die Testversion bei mir gut funktioniert.</p>
<h3>
  
  
  Nächste Schritte 
</h3>

<p>Der nächste Artikel der Reihe befasst sich mit der Einbindung von Fundamentaldaten und Marktkapitalisierung in die Anwendung.</p>


<hr>

<p><em><strong>Ursprünglich veröffentlicht auf EODHD.com, einem One-Stop-Shop für Finanzdaten-APIs, unter dem Titel „AnyChart-Integration für das Financial Trading Dashboard mit Python Django“ im November 2024.</strong></em></p>

<p><em><strong>Geschrieben von Michael Whittle, einem Lösungsarchitekten, Entwickler und Analysten mit über zwanzig Jahren Erfahrung und einem Top-Autor auf Medium.</strong></em></p>


<hr>

<h2>
  
  
  Nützliche AnyChart-Links
</h2>

<ul>
<li> Treemap-Diagramm – Chartopedia
</li>
<li> Aktienchart – Chartopedia
</li>
<li> So erstellen Sie ein Treemap-Diagramm – JavaScript-Diagramm-Tutorials
</li>
<li> So erstellen Sie ein Aktiendiagramm – JavaScript-Charting-Tutorials
</li>
<li> Python / Django / MySQL – Integrationsvorlagen
</li>
<li> Python / Flask / MySQL – Integrationsvorlagen
</li>
<li> Geschäftslösungen und Dashboards
</li>
</ul>


          </div>

            
        </k></stil></kopf>

Das obige ist der detaillierte Inhalt vonPython Django Financial Trading Dashboard – Integration von AnyChart JS-Charts. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Python vs. C: Anwendungen und Anwendungsfälle verglichenPython vs. C: Anwendungen und Anwendungsfälle verglichenApr 12, 2025 am 12:01 AM

Python eignet sich für Datenwissenschafts-, Webentwicklungs- und Automatisierungsaufgaben, während C für Systemprogrammierung, Spieleentwicklung und eingebettete Systeme geeignet ist. Python ist bekannt für seine Einfachheit und sein starkes Ökosystem, während C für seine hohen Leistung und die zugrunde liegenden Kontrollfunktionen bekannt ist.

Der 2-stündige Python-Plan: ein realistischer AnsatzDer 2-stündige Python-Plan: ein realistischer AnsatzApr 11, 2025 am 12:04 AM

Sie können grundlegende Programmierkonzepte und Fähigkeiten von Python innerhalb von 2 Stunden lernen. 1. Lernen Sie Variablen und Datentypen, 2. Master Control Flow (bedingte Anweisungen und Schleifen), 3.. Verstehen Sie die Definition und Verwendung von Funktionen, 4. Beginnen Sie schnell mit der Python -Programmierung durch einfache Beispiele und Code -Snippets.

Python: Erforschen der primären AnwendungenPython: Erforschen der primären AnwendungenApr 10, 2025 am 09:41 AM

Python wird in den Bereichen Webentwicklung, Datenwissenschaft, maschinelles Lernen, Automatisierung und Skripten häufig verwendet. 1) In der Webentwicklung vereinfachen Django und Flask Frameworks den Entwicklungsprozess. 2) In den Bereichen Datenwissenschaft und maschinelles Lernen bieten Numpy-, Pandas-, Scikit-Learn- und TensorFlow-Bibliotheken eine starke Unterstützung. 3) In Bezug auf Automatisierung und Skript ist Python für Aufgaben wie automatisiertes Test und Systemmanagement geeignet.

Wie viel Python können Sie in 2 Stunden lernen?Wie viel Python können Sie in 2 Stunden lernen?Apr 09, 2025 pm 04:33 PM

Sie können die Grundlagen von Python innerhalb von zwei Stunden lernen. 1. Lernen Sie Variablen und Datentypen, 2. Master -Steuerungsstrukturen wie wenn Aussagen und Schleifen, 3. Verstehen Sie die Definition und Verwendung von Funktionen. Diese werden Ihnen helfen, einfache Python -Programme zu schreiben.

Wie lehre ich innerhalb von 10 Stunden die Grundlagen für Computer-Anfänger-Programmierbasis in Projekt- und problemorientierten Methoden?Wie lehre ich innerhalb von 10 Stunden die Grundlagen für Computer-Anfänger-Programmierbasis in Projekt- und problemorientierten Methoden?Apr 02, 2025 am 07:18 AM

Wie lehre ich innerhalb von 10 Stunden die Grundlagen für Computer -Anfänger für Programmierungen? Wenn Sie nur 10 Stunden Zeit haben, um Computer -Anfänger zu unterrichten, was Sie mit Programmierkenntnissen unterrichten möchten, was würden Sie dann beibringen ...

Wie kann man vom Browser vermeiden, wenn man überall Fiddler für das Lesen des Menschen in der Mitte verwendet?Wie kann man vom Browser vermeiden, wenn man überall Fiddler für das Lesen des Menschen in der Mitte verwendet?Apr 02, 2025 am 07:15 AM

Wie kann man nicht erkannt werden, wenn Sie Fiddlereverywhere für Man-in-the-Middle-Lesungen verwenden, wenn Sie FiddLereverywhere verwenden ...

Was soll ich tun, wenn das Modul '__builtin__' beim Laden der Gurkendatei in Python 3.6 nicht gefunden wird?Was soll ich tun, wenn das Modul '__builtin__' beim Laden der Gurkendatei in Python 3.6 nicht gefunden wird?Apr 02, 2025 am 07:12 AM

Laden Sie Gurkendateien in Python 3.6 Umgebungsbericht Fehler: ModulenotFoundError: Nomodulennamen ...

Wie verbessert man die Genauigkeit der Jiebeba -Wortsegmentierung in der malerischen Spot -Kommentaranalyse?Wie verbessert man die Genauigkeit der Jiebeba -Wortsegmentierung in der malerischen Spot -Kommentaranalyse?Apr 02, 2025 am 07:09 AM

Wie löste ich das Problem der Jiebeba -Wortsegmentierung in der malerischen Spot -Kommentaranalyse? Wenn wir malerische Spot -Kommentare und -analysen durchführen, verwenden wir häufig das Jieba -Word -Segmentierungstool, um den Text zu verarbeiten ...

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Herunterladen der Mac-Version des Atom-Editors

Herunterladen der Mac-Version des Atom-Editors

Der beliebteste Open-Source-Editor

MantisBT

MantisBT

Mantis ist ein einfach zu implementierendes webbasiertes Tool zur Fehlerverfolgung, das die Fehlerverfolgung von Produkten unterstützen soll. Es erfordert PHP, MySQL und einen Webserver. Schauen Sie sich unsere Demo- und Hosting-Services an.

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Leistungsstarke integrierte PHP-Entwicklungsumgebung

EditPlus chinesische Crack-Version

EditPlus chinesische Crack-Version

Geringe Größe, Syntaxhervorhebung, unterstützt keine Code-Eingabeaufforderungsfunktion

SecLists

SecLists

SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.