Python Web Development Libraries - Kurzanleitung

Immer wenn ein Benutzer einen Webbrowser wie Google Chrome oder Mozilla öffnet und nach "Webentwicklung" sucht, werden innerhalb kürzester Zeit Tausende von Ergebnissen angezeigt. Was macht das möglich? Web Entwicklung! Es bezieht sich allgemein auf die Arbeit im Zusammenhang mit dem Erstellen, Erstellen und Verwalten von Websites für das Hosting über Intranet oder Internet. Die mit dem Website-Design verbundenen Arbeiten umfassen mehrere Bereiche: Webprogrammierung, Datenbankverwaltung, Webdesign, Web Publishing usw.

Die Webentwicklung umfasst alle Codes, die die Ausführung einer Website beeinflussen. Wir können den gesamten Prozess der Webentwicklung in zwei Kategorien unterteilen:

  • Front-end
  • Back-end

Frontend- und Backend-Webentwicklung unterscheiden sich zwar zweifellos voneinander, sie sind jedoch auch wie zwei Seiten derselben Medaille. Eine vollständige Website basiert darauf, dass jede Seite als eine Einheit effektiv mit der anderen kommuniziert und arbeitet. Sowohl das Front-End als auch das Back-End sind für die Webentwicklung gleichermaßen wichtig.

Das Front-End oder die Client-Seite einer Anwendung ist der Code, der für alles verantwortlich ist, was der Benutzer direkt auf dem Bildschirm erlebt, von Textfarben bis zu Schaltflächen, Bildern und Navigationsmenüs. Einige der allgemeinen Fähigkeiten und Tools, die von Front-End-Entwicklern verwendet werden, sind nachstehend aufgeführt:

  • HTML/CSS/JavaScript
  • CSS-Präprozessoren
  • Frameworks
  • Libraries
  • Git und Github

Im Allgemeinen ist die Back-End- / Serverseite einer Anwendung für die Verwaltung der Informationen in der Datenbank und die Bereitstellung dieser Informationen für das Front-End verantwortlich. Das Backend einer Website besteht aus einem Server, einer Anwendung und einer Datenbank. Im Allgemeinen beinhaltet es alles, was passiert, bevor Sie Ihren Browser aufrufen. Die für die Back-End-Webentwicklung erforderlichen Tools sind:

  • Programming language - Ruby, PHP, Python usw.

  • Database - MySQL, PostgreSQL, MongoDB, Oracle usw.

Warum Webentwicklung?

In der heutigen Welt gibt es mehrere Möglichkeiten, Ihr Unternehmen oder Ihre Fähigkeiten zu fördern und Ihre Ideen auszutauschen. Einige von ihnen sind Werbung durch Websites, native Anwendungen auf Marktplätzen usw. Der Trend, neue Websites als Werkzeug für die Geschäftsentwicklung zu erstellen, gewinnt weltweit rasch an Dynamik. Einige von uns sind sich jedoch möglicherweise nicht der Bedeutung bewusst, die eine Website für das Wachstum eines Unternehmens hat.

Derzeit haben zahlreiche Start-ups Schwierigkeiten, sich auf dem freien Markt zu etablieren. Es ist jedoch auch wahr, dass die meisten von ihnen nicht so viele Zielgruppen gewinnen, wie sie wollen. Ein Hauptgrund, der sie stürzt, ist, dass sie das Potenzial einer voll funktionsfähigen Website unterschätzen, um für sie Geschäfte zu machen. Die Entwicklung von Websites für geschäftliche Zwecke oder andere Zwecke kann sich als recht fruchtbar erweisen.

Lassen Sie uns einige der wichtigen Gründe betrachten, warum die Entwicklung von Websites für das Geschäftswachstum wichtig ist -

Erreichen Sie Ihr Publikum

Online-Websites können ein breitestes Publikum erreichen und sind nicht auf eine Plattform beschränkt, die native Anwendungen einschränkt. Die Zuschauer oder Kunden können einfach von einem Desktop / Laptop auf ein mobiles Gerät zugreifen, da Websites den Inhalt über einen Webbrowser anzeigen können.

Im Vergleich zu nativen Anwendungen ist das Surfen im Internet viel einfacher, da Benutzer nicht auf ihren Geräten auf den App Store zugreifen oder ihre App herunterladen müssen (was einen oder mehrere Prozesse beim Zugriff auf Ihre Inhalte umfassen kann). Die Verteilung Ihrer Daten ist mit webbasierten Anwendungen viel flexibler und agiler als mit nativen Anwendungen, da keine strengen App Store-Anforderungen und Inhaltsbeschränkungen zu beachten sind.

Ein weiteres Tool, das für die Webentwicklung sehr hilfreich ist, ist die Möglichkeit, SEO-Techniken einzusetzen, um Ihre Zielgruppen anzusprechen.

24/7 zugänglich

Anstatt eine physische Verkaufsstelle für das Unternehmen einzurichten, besteht eine gute Chance, ein größeres Publikum online für die Verknüpfung zu gewinnen, wenn der Geschäftsinhaber eine Website als Online-Forum oder ähnliches entwickelt. Dies liegt daran, dass die meisten Menschen den ganzen Tag mit dem Internet verbunden sind.

Im Allgemeinen bevorzugen die Menschen den klügsten Weg, um zuerst online zu prüfen und dann eine Entscheidung zu treffen. Wenn der Geschäftsinhaber also alle grundlegenden Details des Produkts ausfüllt und einen sicheren Weg findet, um das Produkt rechtzeitig zum Kunden zu bringen, bevorzugen die Kunden den Online-Kauf, anstatt die Verkaufsstelle physisch zu besuchen. Auf diese Weise können Benutzer auch in der merkwürdigsten Stunde des Tages darauf zugreifen.

Bequemlichkeit

Eine voll funktionsfähige Website bietet Benutzern einen größeren Vorteil, da sie sich jederzeit einschalten und nach dem suchen können, was sie benötigen. Im Allgemeinen vermeiden Benutzer den physischen Besuch von Geschäften, wenn sie die Möglichkeit haben, diese online zu schalten. Wenn Sie also ein kluger Geschäftsmann sind, möchten Sie lieber alle Details Ihrer Produkte oder Ihrer Geschäfte auf der Website haben, um Geschäfte zu machen, die Sie sonst möglicherweise nicht machen würden.

Globales Marketing

Mit einer Online-Website können Sie Links zu sozialen Foren erstellen und Ihr Produkt / Ihre Dienstleistung an ein großes Publikum auf der ganzen Welt vermarkten. Auf diese Weise können Sie regelmäßig Werbung schalten und Ihre Arbeit in sozialen Foren teilen, um eine viel größere Präsenz der Zielgruppe zu erzielen.

Glaubwürdige Quelle

Ein Online-Portal ist die vertrauenswürdigste Plattform für jedes Unternehmen / jede Organisation. Manchmal können offizielle Websites sogar als alleiniges Büro fungieren. Stellen Sie sich ein Szenario vor, in dem es nicht einfach ist, auf den physischen Standort eines Unternehmens zuzugreifen. In diesem Fall können Sie diese Sorge überwinden, indem Sie sich auf die Website konzentrieren.

Kurz gesagt, durch die Entwicklung einer Website können Sie Ihre Dienste mit wenigen Klicks bewerben und die Aufmerksamkeit von Verbrauchern aus verschiedenen Teilen der Welt auf sich ziehen. Die Website eines Unternehmens kann sich als bemerkenswert erweisen, um nicht nur in kürzerer Zeit, sondern auch mit einem viel größeren Publikum Geschäfte zu machen.

Python ist eine der akzeptabelsten Sprachen unter Web- und Anwendungsentwicklern, da der Schwerpunkt auf Effizienz und Lesbarkeit liegt. Es gibt zahlreiche herausragende Python-Webframeworks mit jeweils eigenen Besonderheiten und Funktionen.

Django

Hier werden einige notwendige Details und Funktionen des Django-Frameworks beschrieben.

Category - Django gehört zum Full-Stack-Python-Framework.

Release - Neueste Version - Version 2.1, häufig verwendete Version - Version 1.8, 1.6.

About- Django wurde von erfahrenen Entwicklern entwickelt und ist ein Python-Webframework auf hoher Ebene, das eine schnelle, saubere und pragmatische Designentwicklung ermöglicht. Django übernimmt einen Großteil der Komplexität der Webentwicklung, sodass Sie sich auf das Schreiben Ihrer App konzentrieren können, ohne das Rad neu erfinden zu müssen. Es ist kostenlos und Open Source.

Um Objekte einer Datenbanktabelle zuzuordnen, verwendet Django ORM und dasselbe wird zum Übertragen von einer Datenbank in eine andere verwendet.

Es funktioniert mit fast allen wichtigen Datenbanken wie Oracle, MySQL, PostgreSQL, SQLite usw.

Es gibt zahlreiche Websites in der Branche, die Django als primäres Framework für die Backend-Entwicklung verwenden.

Eigenschaften von Django

Einige der beispielhaften Funktionen dieses Python-Webframeworks sind:

  • URL-Routing
  • Authentication
  • Migrationen von Datenbankschemata
  • ORM (Object-Relational Mapper)
  • Template Engine

Die offizielle Website für Django Framework ist -https://www.djangoproject.com/

Flasche

Category - Flask gehört zu Non Full-Stack-Frameworks.

Release - 1.0.2 veröffentlicht am 2018-05-02

About- Es wird als Mikro-Framework klassifiziert, da wir keine bestimmten Bibliotheken oder Tools benötigen. Es gibt keine Formularvalidierungs- oder Datenbankabstraktionsschicht oder andere Komponenten, in denen bereits vorhandene Bibliotheken von Drittanbietern gemeinsame Funktionen bereitstellen. Flask unterstützt jedoch mehrere Erweiterungen, die die Anwendungsfunktionen so erweitern, als wären sie in Flask selbst implementiert. Es gibt Erweiterungen für objektrelationale Mapper, Formularvalidierung, Upload-Verarbeitung, verschiedene offene Authentifizierungstechnologien und mehrere gängige Framework-bezogene Tools.

Eigenschaften der Flasche

  • Integrierte Unterstützung für Unit-Tests
  • Erholsamer Versand von Anfragen
  • Enthält Entwicklungsserver und Debugger
  • Verwendet Jinja2-Vorlagen
  • Unterstützung für sichere Cookies
  • Unicode-based
  • 100% WSGI 1.0-konform
  • Umfangreiche Dokumentation
  • Google App Engine-Kompatibilität
  • Erweiterungen verfügbar, um die gewünschten Funktionen zu verbessern

Web2py

Category - Web2py gehört zur Full-Stack-Framework-Familie.

Release - 2.17.1, veröffentlicht am 06.08.2018

About- Python 2.6, 2.7 bis Python 3.x Version. Ohne weitere Abhängigkeiten ist es ein komplettes Paket für sich. Entwicklung, Datenbankverwaltung, Debugging, Bereitstellung, Test und Wartung von Anwendungen können über die Weboberfläche erfolgen, sind jedoch im Allgemeinen nicht erforderlich. Es handelt sich um ein skalierbares Open Source-Framework, das neben einem Code-Editor, einer Ein-Klick-Bereitstellung und einem Debugger über eine eigene webbasierte IDE verfügt.

Funktionen von Web2py

Dieses Framework enthält viele Entwicklungstools und integrierte Funktionen, die den Entwicklern die Komplexität ersparen.

  • Ohne Installation und Konfiguration ist es einfach auszuführen.

  • Unterstützt fast alle gängigen Betriebssysteme wie Windows, Unix / Linux, Mac, Google App Engine und fast alle Webhosting-Plattformen mit Python 2.7 / 3.5 / 3.6 /.

  • Einfache Kommunikation mit MySQL, MSSQL, IBM DB2, Informix, Ingres, MongoDB, SQLite, PostgreSQL, Sybase, Oracle und Google App Engine.

  • Es verhindert die häufigsten Arten von Sicherheitslücken, einschließlich Cross Site Scripting, Injection Flaws und Malicious File Execution.

  • Unterstützt Fehlerverfolgung und Internationalisierung.

  • Lesbarkeit mehrerer Protokolle.

  • Verwendet erfolgreiche Softwareentwicklungspraktiken, die das Lesen und Verwalten von Code vereinfachen.

  • Stellen Sie benutzerorientierte Fortschritte durch Abwärtskompatibilität sicher.

Pyramide

Category - Pyramid ist ein Nicht-Full-Stack-Framework

Release - 1.9.2, veröffentlicht am 23.04.2018

About- Pyramid ist ein kleines, schnelles und bodenständiges Python-Webframework. Es wird im Rahmen des Pylons-Projekts entwickelt. Es ist unter einer BSD-ähnlichen Lizenz lizenziert. Dadurch macht die Entwicklung und Bereitstellung von Webanwendungen in der Praxis mehr Spaß, ist vorhersehbarer und produktiver.

Merkmale der Pyramide

Python Pyramid ist ein Open-Source-Framework mit den folgenden Funktionen:

  • Simplicity - Jeder kann ohne Vorkenntnisse damit beginnen.

  • Minimalism - Pyramid ist sofort einsatzbereit und enthält nur einige wichtige Tools, die für fast jede Webanwendung benötigt werden. Dies kann Sicherheit sein oder statische Assets wie JavaScript und CSS bereitstellen oder URLs an Code anhängen.

  • Documentation - Enthält exklusive und aktuelle Dokumentation.

  • Speed - Sehr schnell und genau.

  • Reliability- Es wurde unter Berücksichtigung der Tatsache entwickelt, dass es konservativ ist und ausführlich getestet wurde. Wenn es nicht richtig getestet wird, gilt es als pleite.

  • Openness - Es wird mit einer zulässigen und offenen Lizenz verkauft.

Strich

Category - Das Dash-Framework gehört zu „anderen“ Python-Webframeworks.

Release - 0,24,1, Core Dash Backend.

About- Dash als Open Source-Bibliothek zum Erstellen interaktiver webbasierter Visualisierungen. Das Plotly-Team hat Dash erstellt - ein Open Source-Framework, das Flask, React.js und plotly.js nutzt, um benutzerdefinierte Datenvisualisierungs-Apps zu erstellen. Das wichtigste Highlight dieser Bibliothek ist, dass Sie hochgradig interaktive Webanwendungen nur über Python-Code erstellen können. Datenwissenschaftler lieben das Dash-Framework, insbesondere alle, die mit der Webentwicklung weniger vertraut sind.

Mit Dash erhalten Entwickler Zugriff auf alle konfigurierbaren Eigenschaften und die zugrunde liegende Flask-Instanz. Die mit dem Dash-Framework entwickelten Anwendungen können auf Servern bereitgestellt und schließlich im Webbrowser gerendert werden.

Dash-Anwendungen sind von Natur aus plattformübergreifend (Linux / Win / Mac) und mobilfreundlich. Die Funktionen von Anwendungen können durch die zahlreichen Flask-Plugins erweitert werden.

Funktionen von Dash

  • Bietet Zugriff auf konfigurierbare Eigenschaften und die Flask-Instanz
  • Durch Flash-Plugins können wir die Funktionen der Dash-Anwendung erweitern
  • Mobile-ready

In diesem Kapitel werden wir ausführlich auf das Django Framework eingehen.

Django ist ein MVT-Webframework, mit dem Webanwendungen erstellt werden. Das riesige Django-Webframework enthält so viele „Batterien“, dass Entwickler oft erstaunt sind, wie alles zusammenarbeitet. Das Prinzip beim Hinzufügen so vieler Batterien besteht darin, gemeinsame Webfunktionen im Framework selbst zu haben, anstatt diese als separate Bibliothek hinzuzufügen.

Einer der Hauptgründe für die Popularität des Django-Frameworks ist die riesige Django-Community. Die Community ist so groß, dass eine separate Website eingerichtet wurde, auf der Entwickler aus allen Bereichen Pakete von Drittanbietern entwickelten, darunter Authentifizierung, Autorisierung, vollwertige CMS-Systeme mit Django-Unterstützung, E-Commerce-Add-Ons usw. Es besteht eine hohe Wahrscheinlichkeit, dass das, was Sie entwickeln möchten, bereits von jemandem entwickelt wurde, und Sie müssen dies nur in Ihr Projekt einbeziehen.

Warum sollten Sie Django verwenden?

Django ist so konzipiert, dass Entwickler ermutigt werden, Websites schnell, sauber und mit praktischem Design zu entwickeln. Djangos praktischer Ansatz, Dinge zu erledigen, ist dort, wo er sich von der Masse abhebt.

Wenn Sie vorhaben, eine hochgradig anpassbare App wie eine Social-Media-Website zu erstellen, ist Django eines der besten Frameworks, die Sie in Betracht ziehen sollten. Die Stärke von Django liegt in der Interaktion zwischen Benutzern oder in der Fähigkeit, verschiedene Medientypen gemeinsam zu nutzen. Einer der großen Vorteile von Django ist die Fähigkeit, großen Community-basierten Support zu nutzen, der Ihnen hochgradig anpassbare Plugins von Drittanbietern zur Verwendung in Ihren Anwendungen bietet.

Im Folgenden sind die zehn wichtigsten Gründe aufgeführt, warum Sie sich für Django für die Webentwicklung entschieden haben:

Python

Python ist aufgrund seiner einfachen Sprachkonstruktionen, Flussstruktur und einfachen Syntax wohl eine der am einfachsten zu erlernenden Programmiersprachen. Es ist vielseitig und führt Websites, Desktop-Anwendungen und mobile Anwendungen aus, die in viele Geräte eingebettet sind, und wird in anderen Anwendungen als beliebte Skriptsprache verwendet.

Batterien enthalten

Django wird mit allgemeinen Bibliotheken geliefert, die für die Erstellung gemeinsamer Funktionen wie URL-Routing, Authentifizierung, einem objektrelationalen Mapper (ORM), einem Templating-System und DB-Schema-Migrationen unerlässlich sind.

Eingebauter Admin

Django verfügt über eine integrierte Verwaltungsoberfläche, mit der Sie Ihre Modelle, Benutzer- / Gruppenberechtigungen verwalten und Benutzer verwalten können. Mit der vorhandenen Modellschnittstelle ist kein separates Datenbankverwaltungsprogramm für alle außer erweiterten Datenbankfunktionen erforderlich.

Stört dich nicht

Durch das Erstellen einer Django-Anwendung werden keine Boilerplate und keine unnötigen Funktionen hinzugefügt. Es gibt keine obligatorischen Importe, Bibliotheken von Drittanbietern und keine XML-Konfigurationsdateien.

Skalierbar

Django basiert auf dem MVC-Entwurfsmuster. Dies bedeutet, dass alle Entitäten wie db (Datenbank), Back-End- und Front-End-Code einzelne Entitäten sind. Mit Django können wir Code von den statischen Medien trennen, einschließlich Bildern, Dateien, CSS und JavaScript, aus denen Ihre Website besteht.

Django unterstützt eine vollständige Liste von Bibliotheken von Drittanbietern für Webserver, Caching, Leistungsmanagement, Clustering und Balancing. Einer der Vorteile von Django ist die Unterstützung wichtiger E-Mail- und Messaging-Anwendungen und -Dienste wie ReST und OAuth.

Schlacht getestet

Django wurde 2005 zum ersten Mal als Open-Source-Unternehmen eingeführt. Nach 12 Jahren Wachstum betreibt Django nun nicht nur Websites für Nachrichtenveröffentlichungen, sondern auch alle oder einen Teil eines großen globalen Unternehmens wie Pinterest, Instagram, Disqus, Bitbucket, EventBrite und Zapier. Dies macht es zu einem robusten und zuverlässigen Webframework, mit dem gearbeitet werden kann.

Riesige Paketunterstützung

Aufgrund der großen Community-Unterstützung und des riesigen Entwicklernetzwerks besteht eine hohe Wahrscheinlichkeit, dass alles, was Sie beabsichtigen, zuvor getan wurde. Eine große internationale Entwicklergemeinschaft trägt zur Community bei, indem sie ihre Projekte als Open-Source-Pakete veröffentlicht.

Ein solches Repository dieser Projekte ist die Django Package-Site. Derzeit sind in Django-Paketen über 3400 plus wiederverwendbare Django-Apps, Websites und Tools aufgeführt, die in unseren Django-Projekten verwendet werden können.

Aktiv entwickelt

Eines der größten Risiken im Zusammenhang mit Open Source-Projekten ist die Nachhaltigkeit. Wir können nicht sicher sein, ob es lange dauert.

Bei Django besteht kein solches Risiko, da es 12 Jahre alt ist. Die konsistenten Releases, neueren / besseren Versionen und die aktive Community wachsen täglich mit einem großen Kernteam freiwilliger Mitarbeiter, die die Codebasis täglich pflegen und verbessern.

Stabile Releases

Open-Source-Softwareprojekte wie Django sind in vielen Fällen aktiv entwickelt und sicherer als konkurrierende proprietäre Software, da viele Entwickler sie täglich entwickeln und testen. Der Nachteil eines Open-Source-Softwareprojekts ist jedoch das Fehlen einer stabilen Codebasis für eine wirtschaftlich tragfähige Entwicklung.

In Django haben wir LTS-Versionen (Long Term Support) der Software und einen definierten Release-Prozess, wie im folgenden Bild gezeigt.

Erstklassige Dokumentation

Von der ersten Version an haben die Django-Entwickler dafür gesorgt, dass ausreichend umfassende Dokumente verfügbar sind und die Tutorials leicht verständlich sind.

Wer benutzt Django?

Aufgrund der einzigartigen Stärke des Django gibt es mehrere beliebte Websites, die mit Python auf dem Django-Framework erstellt werden. Im Folgenden sind einige der wichtigsten Standorte aufgeführt, die ganz oder teilweise auf Django basieren.

Disqus

Es ist eine der weltweit am meisten bevorzugten Websites zum Hosten von Blog-Kommentaren. Die Integration in die gängigsten CMS (Content Management Systeme) wie WordPress und viele andere über Disqus ist einfach. Mit einer Nutzerbasis von über 50 Millionen ist Django in der Lage, die Websitebesitzer zufrieden zu stellen, um ihre Communitys zu erreichen.

Die Zwiebel

Die Onion-Website, die einen Online-Veranstaltungsort für ihre satirische Zeitung bietet, bietet Django den Rahmen dafür.

Bit Bucket

Bitbucket ist wie GitHub, ein Versionskontroll-Repository-Hosting-Service. Der einzige Unterschied zwischen Bitbucket und GitHub besteht darin, dass Bitbucket Quecksilber-Repositorys hostet, während GitHub Git-Repositorys hostet. Da Millionen von Benutzern mit Bitbucket verbunden sind und alle von Bitbucket bereitgestellten Dienste (wie das Erstellen eines Repos, das Verschieben Ihres Codes, das Hinzufügen von Mitarbeitern, Commits, das Abrufen von Anforderungen usw.) stabil sein müssen. Django ist für den Betrieb der Bitbucket-Site verantwortlich.

Instagram

Instagram ist eine Social-Networking-App, die speziell für diejenigen entwickelt wurde, die gerne Fotos und Videos an alle ihre Freunde weitergeben. Derzeit gibt es viele Prominente auf Instagram, um näher an ihren Fans zu bleiben. Das Django-Framework führt auch Instagram aus.

Mozilla Firefox

Der zweithäufigste Browser der Welt nach Google Chrome ist der Mozilla-Browser. Jetzt wird die Hilfeseite von Mozilla mit dem Django-Framework erstellt.

Pinterest

Millionen von Nutzern auf der ganzen Welt entdecken ihre neuen Ideen und Inspirationen von Pinterest. Pinterest verwendet das Django-Framework (vorgenommene Änderung gemäß den Anforderungen), um es auszuführen.

NASA

Auf der offiziellen Website der National Aeronautics and Space Administration können Millionen von Nutzern die Nachrichten, Bilder, Videos und Podcasts der Premiere-Agentur besuchen und ansehen. Django entwickelt einige spezifische Teile der offiziellen NASA-Website.

Die Washington Post

Wenn es eine einflussreiche Zeitung auf der Welt gibt, ist es sicherlich die Washington Post. Die Website der Washington Post ist eine äußerst beliebte Online-Nachrichtenquelle, die ihre Tageszeitung begleitet. Die enorme Menge an Ansichten und Datenverkehr wurde vom Django-Webframework problemlos verarbeitet.

Reddit Geschenke

Die äußerst beliebte Reddit-Website hat eine anonyme Online-Plattform für den Austausch von Geschenken und Meetups namens Reddit Gifts gestartet. Die Website verbindet Benutzer aus der ganzen Welt und erleichtert den Austausch von Geschenken zwischen ihnen. Das Django-Webframework unterstützt seine Funktionen.

Prezi

Prezi ist eine Cloud-basierte Alternative zu Microsoft PowerPoint, die auf dem Django-Framework basiert. Die Site bietet eine virtuelle Leinwand, die bearbeitet und vergrößert und verkleinert werden kann. Dies bietet die gesamte Ansicht der Präsentation und nicht einzelne Folien.

Installieren und Erstellen eines Django-Projekts und einer App

Vor der Installation von Django müssen wir sicherstellen, dass Python installiert ist. Angenommen, Sie verwenden virtualenv, sollte eine einfache Pip-Installation von Django ausreichen.

Installation der virtuellen Umgebung und von Django

Im Folgenden wird beschrieben, wie Sie die virtuelle Umgebung und Django in Ihrer Windows-Umgebung installieren.

Geben Sie den folgenden Code ein, um zu überprüfen, ob der Django ordnungsgemäß installiert ist.

Django-Projekt erstellen

Sobald die Installation abgeschlossen ist, müssen wir ein Django-Projekt erstellen.

Wenn Sie den folgenden Befehl auf Ihrem Windows-Computer ausführen, wird das folgende Django-Projekt erstellt:

django-admin startproject my_project_name

Wenn Sie dir eingeben, werden eine neue Datei und ein neues Verzeichnis angezeigt, wie oben gezeigt.

manage.py- manage.py ist eine befehlszeilenausführbare Python-Datei, die nur ein Wrapper um django-admin ist. Es hilft uns bei der Verwaltung unseres Projekts, das auch in seinem Namen enthalten ist.

Damit wurde ein Verzeichnis mit dem Namen erstellt. myFirstDjangoProjectin myFirstDjangoProject, das den Konfigurationsstamm für unser Projekt darstellt. Lassen Sie uns viel tiefer in das Thema eintauchen.

Django konfigurieren

Wenn Sie das myFirstDjangoProject-Verzeichnis als "Konfigurationsstamm" bezeichnen, bedeutet dies, dass dieses Verzeichnis die Dateien enthält, die für die allgemeine Konfiguration unseres Django-Projekts erforderlich sind. Nahezu alles außerhalb dieses Verzeichnisses konzentriert sich ausschließlich auf die „Geschäftslogik“, die mit den Modellen, Ansichten, Routen usw. des Projekts verbunden ist. Alle Punkte, die das Projekt miteinander verbinden, führen hierher.

  • __init__.py - Dies ist leer und ändert das Verzeichnis in ein importierbares Python-Paket.

  • settings.py - Wie der Name schon sagt, werden hier die meisten Konfigurationselemente festgelegt.

  • urls.py - Die URLs werden mit urls.py festgelegt. Damit müssen wir nicht jede URL für das Projekt explizit in diese Datei schreiben. Wir müssen Django jedoch mitteilen, wo die URLs deklariert wurden (dh wir müssen eine andere URL in urls.py verknüpfen).

  • Wsgi.py - Dies dient zur Unterstützung der Anwendung in der Produktion und ähnelt anderen Anwendungen wie Flask, Tornado, Pyramid, die ein App-Objekt verfügbar machen.

Einstellungen vornehmen

Ein Blick in settings.py zeigt die beachtliche Größe - und dies sind nur die Standardeinstellungen. Andere Dinge, die wir beachten müssen, sind die statischen Dateien, Datenbanken, Mediendateien, die Cloud-Integration oder andere Dutzende von Möglichkeiten, wie ein Django-Projekt konfiguriert werden kann. Lassen Sie uns einige Punkte verstehen, die in der Datei settings.py erwähnt werden -

  • BASE_DIR- Dies ist hilfreich beim Auffinden von Dateien. In der Datei settings.py legt der Parameter BASE_DIR den absoluten Pfad zum Basisverzeichnis fest.

  • SECRET_KEY- Es wird zur Herstellung von Hashes verwendet. Im Allgemeinen haben wir secret_key für Cookies, Sitzungen, CSF-Schutz und Authentifizierungstoken verwendet.

  • DEBUG - Wir können festlegen, dass das Projekt entweder im Entwicklungs- oder im Produktionsmodus ausgeführt wird.

  • ALLOWED_HOSTS- Wir stellen die Liste der Hostnamen bereit, über die unsere Anwendung bereitgestellt wird. Im Entwicklungsmodus ist die Einstellung optional. In der Produktionsmaschine müssen wir jedoch unser Django-Projekt festlegen.

  • INSTALLED_APPS- Dies ist die Liste der Django-Apps, die derzeit in unserem Django-Projekt installiert sind und ausgeführt werden. Der integrierte Django bietet sechs installierte Apps wie folgt:

    • 'django.contrib.admin'

    • 'django.contrib.auth'

    • django.contrib.

    • django.contrib.sessions

    • django.contrib.messages

    • django.contrib.staticfiles

  • MIDDLEWARE- Es hilft unserem Django-Projekt zu laufen. Es ist eine Python-Klasse, die sich in die Django-Anforderungs- / Antwortverarbeitung einfügt.

  • TEMPLATES- Es definiert, wie das Dokument im Frontend angezeigt werden soll. Django-Vorlagen werden zum Erstellen eines beliebigen textbasierten Formats verwendet.

  • WSGI_APPLICATION- Jeder von uns eingerichtete Server muss wissen, wo sich die WSGI-Datei befindet. Wenn Sie einen externen Server verwenden, wird dieser in seinen eigenen Einstellungen angezeigt. Standardmäßig zeigt es auf Objekte in wsgi.py.

  • DATABASES- Es werden die Datenbanken festgelegt, auf die unser Django-Projekt derzeit zugreift. Es ist obligatorisch, die Standarddatenbank festzulegen. Wenn wir die Datenbank unserer Wahl festlegen, müssen wir einige Dinge erwähnen, die mit der Datenbank zusammenhängen, wie z. B. HOST, USER, PASSWORD, PORT, Datenbankname und den entsprechenden ENGINE.

  • STATIC_URL- Dies ist die URL, die verwendet wird, wenn auf statische Dateien in STATIC_ROOT verwiesen wird. Standardmäßig ist es Keine.

Möglicherweise müssen wir jedoch einen Pfad für statische Dateien hinzufügen. Gehen Sie zum Ende der Datei und fügen Sie direkt unter dem Eintrag STATIC_URL einen neuen hinzu, der STATIC_ROOT heißt (siehe unten).

myFirstDjangoProject/settings.py

STATIC_URL = '/ static /'

STATIC_ROOT = os.path.join (BASE_DIR, 'statisch')

Einrichten einer Datenbank

Es gibt viele verschiedene Datenbanksoftware, die das Datum für Ihre Site speichern können. Wir verwenden die Standardeinstellung sqlite3.

Dies ist bereits im unten angegebenen Teil von Ihnen eingerichtet myFirstDjangoProject/settings.py - -

DATABASES = {
   'default': {
      'ENGINE': 'django.db.backends.sqlite3',
      'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
   }
}

Um eine Datenbank für unser Blog zu erstellen, führen Sie Folgendes in der Konsole aus: python manage.py migrate (Wir müssen uns im Verzeichnis myFirstDjangoProject befinden, das die Datei manage.py enthält.

Sie erhalten die folgende Ausgabe, wenn alles gut geht -

Starten des Webservers

Sie müssen sich in dem Verzeichnis befinden, das die Datei manage.py enthält. In der Konsole können wir den Webserver starten, indem wir python manage.py runserver wie folgt ausführen:

Jetzt müssen Sie nur noch überprüfen, ob Ihre Website ausgeführt wird. Öffnen Sie Ihren Browser (Firefox, Chrome, Safari, Internet Explorer oder was auch immer Sie verwenden) und geben Sie diese Adresse ein -

http://127.0.0.1:8000/

oder

http://localhost:8000/ # Da unser Webserver nur auf unserem lokalen Computer ausgeführt wird.

Herzliche Glückwünsche! Sie haben gerade Ihre erste Website erstellt und auf einem Webserver ausgeführt!

Während der Webserver ausgeführt wird, wird keine neue Eingabeaufforderung zur Eingabe zusätzlicher Befehle angezeigt. Das Terminal akzeptiert den nächsten Text, führt jedoch keine neuen Befehle aus. Dies liegt daran, dass der Webserver kontinuierlich ausgeführt wird, um eingehende Anforderungen abzuhören.

Django Modelle

Wir versuchen, ein Django-Modell zu erstellen, in dem alle Beiträge in unserem Blog gespeichert werden. Aber um sicherzustellen, dass es funktioniert, müssen wir etwas über Objekte lernen.

Objekte

Objekte ist eine Sammlung von Eigenschaften und Aktionen. Lassen Sie uns dies anhand eines Beispiels verstehen. Angenommen, wir möchten eine Katze modellieren, dann erstellen wir ein Objekt namens Katze, das Eigenschaften wie Farbe, Alter, Stimmung (gut / schlecht / schläfrig) und Besitzer aufweist.

Dann hat die Katze einige Aktionen: Schnurren, Kratzen oder Füttern.

Cat 
-------- 
color 
age 
mood 
owner 
purr() 
scratch() 
feed(cat_food) 
CatFood 
-------- 
taste

Im Grunde versuchen wir also, reale Dinge im Code mit Eigenschaften (als Objekteigenschaften bezeichnet) und Aktionen (als Methoden bezeichnet) zu beschreiben.

Während wir ein Blog erstellen, benötigen wir Textinhalte und einen Titel. Es ist auch erforderlich, den Namen des Autors, das Erstellungsdatum und das Veröffentlichungsdatum anzugeben.

Unser Blog wird also die folgenden Objekte haben -

Post 
-------- 
title 
text 
author 
created_date 
published_date

Außerdem benötigen wir eine Methode, mit der dieser Beitrag veröffentlicht wird. Da wir jetzt wissen, was ein Objekt ist, können wir ein Django-Modell für unseren Blog-Beitrag erstellen.

Ein Modell ist eine spezielle Art von Objekt in Django und wird in der Datenbank gespeichert. Wir werden unsere Daten in der SQLite-Datenbank speichern.

Eine Anwendung erstellen

Um alles klar zu halten, erstellen wir innerhalb unseres Projekts eine separate Anwendung. Im Folgenden versuchen wir, eine Blog-Webanwendung zu erstellen, indem wir den unten genannten einfachen Befehl ausführen.

Jetzt werden wir feststellen, dass ein neues myBlog-Verzeichnis erstellt wird, das jetzt eine Reihe von Dateien enthält. Die Verzeichnisse und Dateien in unserem Projekt sollten wie folgt aussehen:

Nach dem Erstellen einer Anwendung müssen wir Django auch anweisen, sie zu verwenden. Das machen wir in der Datei myFirstDjangoProject / settings.py.

INSTALLED_APPS = [
   'django.contrib.admin',
   'django.contrib.auth',
   'django.contrib.contenttypes',
   'django.contrib.sessions',
   'django.contrib.messages',
   'django.contrib.staticfiles',
   'myBlog',
]

Erstellen eines Blogpost-Modells

In dem myBlog/models.py Datei definieren wir alle Objekte namens Modelle - dies ist ein Ort, an dem wir unseren Blog-Beitrag definieren werden.

Öffnen wir myBlog / models.py, entfernen Sie alles daraus und schreiben Sie den Code wie folgt:

Zunächst importieren wir einige Funktionen aus anderen Dateien, indem wir sie aufrufen oder importieren. Anstatt die gleichen Dinge in jede Datei zu kopieren und einzufügen, können wir damit einige Teile einfügenfrom and import.

class Post(models.Model) - Diese Linie definiert unser Modell (es ist ein Objekt).

  • Klasse ist ein spezielles Schlüsselwort, das angibt, dass wir ein Objekt definieren.

  • Post ist der Name unseres Modells. Beginnen Sie einen Klassennamen immer mit einem Großbuchstaben.

  • models.Model bedeutet, dass der Beitrag ein Django-Modell ist, sodass Django weiß, dass er in der Datenbank gespeichert werden sollte.

Lassen Sie uns nun die oben definierten Eigenschaften diskutieren: Titel, Text, Erstellungsdatum, Veröffentlichungsdatum und Autor. Dazu müssen wir den Typ jedes Feldes definieren.

  • models.CharField - So definieren Sie Text mit einer begrenzten Anzahl von Zeichen.

  • Models.TextField - Dies ist für Langtext ohne Einschränkung.

  • Models.DateTimeField - Dies ist für Datum und Uhrzeit.

  • Models.ForeignKey - Dies ist ein Link zu einem anderen Modell.

Wir definieren eine Funktion / Methode mit def und veröffentlichen ist der Name der Methode.

Methoden geben oft etwas zurück. Wenn wir hier __str __ () aufrufen, erhalten wir einen Text (String) mit einem Post-Titel.

Erstellen von Tabellen für Modelle in Ihrer Datenbank

Der letzte Schritt ist das Hinzufügen eines neuen Modells zu unserer Datenbank. Zuerst müssen wir Django verstehen lassen, dass wir einige Änderungen an unserem Modell vorgenommen haben. Lassen Sie uns dasselbe in unserem Konsolenfenster mit Befehl tunpython manage.py make migrations myBlog wie unten gezeigt -

Anschließend bereitet Django eine Migrationsdatei vor, die wir nun auf unsere Datenbank anwenden müssen. In unserer Konsole können wir Folgendes eingeben:python manage.py migrate myBlog und die Ausgabe sollte wie folgt sein -

Unser Post-Modell befindet sich jetzt in unserer Datenbank.

Django Admin

Zum Hinzufügen, Bearbeiten und Löschen der gerade modellierten Beiträge verwenden wir den Django-Administrator.

Also lasst uns das öffnen myBlog/admin.py file und setzen Sie unten Inhalt in diese -

Zunächst importieren (schließen) wir das im vorherigen Kapitel definierte Post-Modell ein. Um unser Modell auf der Admin-Seite sichtbar zu machen, müssen wir das Modell bei admin.site.register (Post) registrieren.

Um sich bei einer Admin-Site anzumelden, müssen Sie einen Superuser erstellen - ein Benutzerkonto, das die Kontrolle über alles auf der Site hat. Stoppen Sie also den Webserver und geben Sie die Befehlszeilenpython einmanage.py createsuperuserund drücken Sie die Eingabetaste.

Ok, es ist Zeit, sich unser Post-Modell anzusehen. Denken Sie daran, python manage.py run server in der Konsole auszuführen, um den Webserver auszuführen. Gehen Sie zu Ihrem Browser und geben Sie die Adresse einhttps://127.0.0.1:8000/admin/.Melden Sie sich mit den soeben ausgewählten Anmeldeinformationen an. Dann sollte das Django-Administrator-Dashboard wie folgt angezeigt werden:

Gehen Sie zu Beiträge und experimentieren Sie ein wenig damit. Sie können von überall aus viele Blog-Beiträge und Inhalte hinzufügen. Ihr Blog wird ungefähr so ​​aussehen -

Dies ist nur eine Übersicht über Django und wir können ein Blog mit nur wenigen Codezeilen erstellen.

Flask ist ein Mikro-Framework, das nur sehr wenig von externen Bibliotheken abhängig ist. Es ist ein sehr leichter Rahmen und gibt uns die Freiheit, zu tun, was wir wollen.

In diesem Kapitel erstellen wir ein Projekt mit dem Python- und Flask-Framework.

Start und Konfiguration des Kolbens

Wie die meisten weit verbreiteten Python-Bibliotheken kann das Flask-Paket über den Python Package Index (PPI) installiert werden. Lassen Sie uns zuerst ein Verzeichnis erstellen (In diesem Kapitel haben wir ein Verzeichnis mit dem Namen erstelltflaskProject) erstellte dann eine virtuelle Umgebung (und nannte sie als flaskEnv) wo alle projektbezogenen Abhängigkeiten geladen werden (einschließlich Flasche). Sie können flask-sqlalchemy auch installieren, damit Ihre flask-Anwendung auf einfache Weise mit der SQL-Datenbank kommunizieren kann.

Nach der Installation des Kolbens zeigt Ihr flaskEnv (unser Name für virtualEnvironment) Folgendes an:

Erstellen einer App mit Flasche

Durch die Installation der Flasche können wir eine einfache “hello application in flask”Mit sehr wenigen Codezeilen wie folgt -

Geben Sie Folgendes in das Terminal ein -

$python flaskapp.py

Und Sie können die folgende Ausgabe sehen -

Laufen weiter http://127.0.0.1:5000/ oder weiter localhost:5000

Nachfolgend finden Sie eine Erklärung dessen, was wir in unserem Beispielcode getan haben -

  • Zunächst importieren wir die Flask-Klassenbibliothek. Eine Instanz aus dieser Klasse ist die WSGI-App.

  • Zweitens erstellen wir eine Instanz dieser Klasse. Anwendungspaket oder Modulname ist unser erstes Argument. Es ist zwingend erforderlich, dass flask weiß, wo sich statische Dateien, Vorlagen und andere Dateien befinden.

  • Als nächstes folgt der route () - Dekorator, mit dem wir wissen, welche URL unsere Methode / Funktion auslösen soll.

URL-Routing erstellen

Durch das URL-Routing sind URLs in Ihrer Web-App leicht zu merken. Wir werden jetzt einige URL-Routen erstellen -

/hello
/members
/members/name

Wir können den folgenden Code basierend auf der obigen URL schreiben und ihn als app.py speichern.

from flask import Flask, render_template

app = Flask(__name__)

@app.route('/')
def index():
   return "Index!"
	
@app.route('/Hello')
def hello():
   return "Hello, World!"
	
@app.route("/members")
def members():
   return "Members"
	
@app.route("/members/<name>/")
def getMember(name):
   return name
	
if __name__ == '__main__':
   app.run(debug=True)
$ python app.py

Running on http://localhost:5000/

Wir erhalten die folgende Ausgabe in unserem Browser -

Wir können andere URLs in unserem Browser wie folgt ausprobieren:

Running on http://localhost:5000/hello, will give the following output −

Running on http://localhost:5000/members, will give −

Running on http://localhost:5000/members/TutorialsPoint/, will give you the following output −

Normalerweise möchten wir jedoch keine Zeichenfolge zurückgeben (wie oben), sondern Vorlagen zurückgeben. Dafür wollen wir eine Funktion verwenden “render_template”Aus der Flasche und geben render_template mit einigen Eingaben zurück. Die folgende Funktion erledigt also unsere Arbeit -

from flask import render_template
return render_template(‘home.html’)

Lassen Sie uns eine Ordnervorlage erstellen und die Datei home.html darin ablegen.

Als nächstes werden wir über das Layout diskutieren. Anstatt für jede einzelne Vorlage ein HTML-Head-Tag und ein Body-Tag zu verwenden, entwerfen wir ein Layout, das Head- und Body-Tags enthält und die aktuellen Ansichten oder die aktuelle Vorlage umschließt. Dazu müssen wir eine separate Datei erstellen und aufrufenlayout.html. Hier können wir unser normales Head-Tag, Body-Tag und alle anderen erforderlichen Tags einfügen.

Wir können unsere neue layout.html mit den folgenden Codezeilen erstellen:

<!DOCTYPE html>
<html>
   <head>
      <meta charset="utf-8">
      <title>MyFlaskApp</title>
      <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css">
   </head>
   <body>
      {% include 'includes/_navbar.html' %}
      <div class="container">
      {% block body %}
      {% endblock %}
      </div>
      <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/js/bootstrap.min.js">
      </script>
   </body>
</html>

Im obigen Code haben wir den Titeltrack MyFlaskAp angegeben, verwenden css cdn im Kopf und Javascript im Bodyblock, um den Bootstrap zu aktivieren.

Jetzt müssen wir für jede einzelne Seite eine Navigationsleiste erstellen. Dazu müssen wir zuerst einen Include-Ordner erstellen und dann die Datei _navbar.html darin erstellen. Jetzt müssen wir in der Datei _navbar.html die Standard-Starter-Vorlage von getbootstrap.com verwenden. Die neu erstellte Datei _navbar.html lautet wie folgt:

Fügen Sie diese Datei _navbar.html in unsere Datei layout.html ein.

{% include 'includes/_navbar.html' %}

Da wir den Layoutblock haben, können wir diesen Block in unserer Home-Datei (home.html) erweitern.

Unsere home.html-Datei kann mit dem folgenden Code erstellt werden:

{% extends 'layout.html' %}
{% block body %}
   <div class="jumbotron text-center">
      <h1>Welcome to FlaskApp</h1>
      <p>This application is built on Flask webframework!</p>
   </div>
{% endblock %}

Wenn wir damit versuchen, unsere Datei flaskapp.py auszuführen, können wir die folgende Ausgabe in unserem Browser sehen -

Jetzt möchten wir unsere aktivieren (derzeit funktionieren die Registerkarten nicht) aboutTab. Erstellen Sie eine Route für die Registerkarte "Info" und erstellen Sie eine Vorlagendatei.about.html.

Informationen zur Registerkarte Route in appflask.py finden Sie wie folgt:

Die Datei about.html enthält den folgenden Inhalt:

So sind nun Home und About erledigt. Für Artikel können wir eine neue Datei (data.py) im Stammverzeichnis erstellen, in der wir die Daten ablegen und auf unserer Webseite aufrufen.

data.py

def Articles():
   articles = [
      {
         'uid': 1,
         'title': 'Article_One',
         'body': 'Flask, being a microframework, often requires some repetitive step
            to get a third party library working. Because very often these steps could 
            be abstracted to support multiple projects the Flask Extension Registry 
            was created.',
         'Author': 'Rajesh Joshi',
         'Created-on': '07-09-2018'
      },
      {
         'uid': 2,
         'title': 'Article_Two',
         'body': "Flask, being a microframework, often requires some repetitive steps
            to get a third party library working. Because very often these steps could 
            be abstracted to support multiple projects the Flask Extension Registry 
            was created.",
         'Author': 'Rajesh J',
         'Created-on': '07-09-2018'
      },
      {
         'uid': 3,
         'title': 'Article_Three',
         'body': 'Flask, being a microframework, often requires some repetitive steps
            to get a third party library working. Because very often these steps could be
            abstracted to support multiple projects the Flask Extension Registry 
            was created.',
         'Author': 'Joshi Rajesh',
         'Created-on': '07-09-2018'
      }
   ]
   return articles

Unten ist der Code für articles.html, in dem Artikeltitel für jede UID angezeigt werden.

{% extends 'layout.html' %}
{% block body %}
   <h1>Articles</h1>
   {% for article in articles %}
      <li class="list-group-item">
         <a href="article/{{article.uid}}"> {{article.title}}</a>
      </li>
   {% endfor %}
{% endblock %}

Zusammenfassend ist Flask aufgrund seines geringen Gewichts eines der beliebtesten Python-Webframeworks. Obwohl es sich um ein Mikro handelt, handelt es sich um ein erweiterbares Python-Webframework. Durch die Bereitstellung der erforderlichen Funktionalität beschleunigt flask die Entwicklung einfacher Webanwendungen. So ist Flask besser für kleinere, weniger komplizierte Anwendungen geeignet.

Web2py ist ein benutzerfreundliches Framework. Mit web2py ist keine Installation und Konfiguration erforderlich, da es portabel ist und auch auf einem USD-Laufwerk ausgeführt werden kann. Es basiert auf den MVC-Frameworks wie viele andere Python-Frameworks. Obwohl die meisten von ihnen ältere Versionen von Python nicht unterstützen, unterstützt web2py immer noch ältere Versionen: Python 2.6 und 2.7. Es unterstützt auch LDAP für die Authentifizierung, was heutzutage allgemein akzeptiert wird.

Web2py versucht, die Eintrittsbarriere für die Webentwicklung zu senken, indem es sich auf drei Hauptziele konzentriert:

  • Schnelle Entwicklung
  • Benutzerfreundlichkeit
  • Security

Unter Berücksichtigung der Benutzerperspektive wurde Web2py intern entwickelt und ständig optimiert, um es zu einem schnelleren und schlankeren Framework zu machen, einschließlich Unterstützung für Abwärtskompatibilität.

Installieren und Konfigurieren von Web2py Framework

Das Ausführen eines web2py ist einfach. Sie müssen die Exe über den folgenden Link herunterladen: http://www.web2py.com/init/default/download

Unter Windows können Sie die Zip-Datei herunterladen, entpacken und die exe-Datei entweder direkt oder über die Befehlszeile ausführen. Sie werden im folgenden Bildschirm aufgefordert, nach dem Administratorkennwort zu fragen.

Sie können ein Administratorkennwort auswählen und den Server starten. Sie sehen den folgenden Bildschirm -

Erstellen einer App mit Web2py

Jetzt können wir eine neue App erstellen. Klicken Sie unten auf die Registerkarte "Admin". Nach Eingabe des Administratorkennworts wird der folgende Bildschirm angezeigt:

Gehen Sie zu einer neuen einfachen Anwendung, geben Sie einen Anwendungsnamen ein (wie helloWeb2py) und klicken Sie auf Erstellen. Daraufhin wird die Seite mit der Entwurfsoberfläche wie unten angegeben angezeigt.

Sie können auch zu Ihrem aktuellen Live-Web gehen, helloWeb2py, einfach eingeben http://127.0.0.1:8000/helloWeb2py Auf Ihrem lokalen Computer erhalten Sie die folgende Ausgabe:

Gehen Sie auf der Entwurfsseite der Anwendung helloWeb2py zum Controller und klicken Sie auf die Schaltfläche Bearbeiten neben default.py. Wenn Sie den Rückgabewert der Funktion index () ändern, wird die folgende Ausgabe angezeigt:

Speichern Sie die Änderungen, und jetzt können Sie die in Ihrer helloWeb2py-App vorgenommenen Änderungen überprüfen. Aktualisieren Sie einfach diehttp://127.0.0.1:8000/helloWeb2py Link und Sie sehen die folgende Ausgabe -

Bereitstellen der App auf einer Cloud-Plattform

Wenn Sie Ihre App jetzt auf einer Cloud-Plattform bereitstellen möchten, kehren Sie zu Ihrer Startseite zurück und klicken Sie auf die Site. Sie können eine beliebige Option für die Bereitstellung auswählen. Hier wählen wir "pythonAnywhere". Gehen Sie zur pythonAnywhere-Website und registrieren Sie sich (falls noch nicht geschehen). Klicke auf“Add a new web app”und füllen Sie alle Anmeldeinformationen aus (wählen Sie die web2py-App). Alles erledigt.

Jetzt geh zu https://username.pythonanywhere.com/welcome/default/indexKlicken Sie auf die Registerkarte Admin (geben Sie das Passwort ein). Klicken Sie anschließend auf Upload und installieren Sie die gepackte Anwendung. Füllen Sie die Anmeldeinformationen wie folgt aus und klicken Sie auf Installieren.

Sobald alles erledigt ist, erscheint eine Popup-Meldung wie unten angegeben -

Um Ihre App anzuzeigen, öffnen Sie den folgenden Link -

https://username.pythonanywhere.com/welcome/default/index und Sie können den folgenden Bildschirm sehen -

Unsere erste web2py-Anwendung wurde erfolgreich erstellt und bereitgestellt.

Zusammenfassend ist Web2py ein kostenloses, schnelles und sicheres Webentwicklungsframework, das vollständig in Python geschrieben ist und die Verwendung von Python auf jede mögliche Weise (Modell, Ansicht, Controller) fördert. Es ist ein sehr gutes Framework für kleine Webanwendungen oder Prototypen, erfüllt jedoch nicht die Qualitätsanforderungen der Enterprise-Klasse. Dies liegt daran, dass in einer Anwendung auf Unternehmensebene die Komplexität der Fehlerbehebung aufgrund fehlender Komponententests, guter und genauer Fehlerberichte und verstreuter Modelle exponentiell zunimmt.

Pyramid ist ein allgemeines Open Source-Framework für die Entwicklung von Webanwendungen, das in Python erstellt wurde. Damit können Python-Entwickler problemlos Webanwendungen erstellen.

Installieren, Starten und Konfigurieren

Wie beschrieben, "das Start-Small-, Finish-Big-, Stay-Finish-Framework", ähnelt Pyramid Flask, dessen Installation und Ausführung nur sehr wenig Aufwand erfordert. In der Tat werden Sie erkennen, dass einige der Muster Flask ähnlich sind, sobald Sie mit dem Erstellen dieser Anwendung beginnen.

Im Folgenden finden Sie die Schritte zum Erstellen einer Pyramiden-Framework-Umgebung:

  • Erstellen Sie zunächst ein Projektverzeichnis. Hier haben wir ein Verzeichnis mit dem Namen erstelltpyramidProject (Sie können einen beliebigen Namen wählen).

  • Erstellen Sie als Nächstes eine virtuelle Umgebung, in der Sie alle projektspezifischen Abhängigkeiten installieren. Hier haben wir einen Ordner für die virtuelle Umgebung mit dem Namen erstelltpyramidEnv wo Pyramid installiert ist.

  • Dann gehen Sie in das Verzeichnis, pyramidEnv und installieren Sie die Pyramide mit pip install pyramid.

Sobald alles wie oben erwähnt erledigt ist, sieht Ihre Verzeichnisstruktur wie folgt aus:

Und die im System installierte Pyramidenversion ist unten angegeben -

Kernkonzepte

Das Pyramid-Framework basiert auf den folgenden Kernkonzepten:

  • Zope (Erweiterbarkeit, Durchquerung, deklarative Sicherheit) - Pyramid basiert in Bezug auf Erweiterbarkeit, das Konzept der Durchquerung und die deklarative Sicherheit lose auf Zope.

  • Pylons(URL-Versand, nicht meinungsgebundene Ansicht der Persistenz, Vorlage usw.) - Ein weiterer Bereich, aus dem die Pyramide ihr Konzept bezieht, ist das Pylons-Projekt. Pylone haben das Konzept von Routen, das den URL-Versand innerhalb des Pyramiden-Frameworks aufruft, und sie haben auch die nicht meinungsgebundene Ansicht der Persistenzschicht oder des Templating.

  • Django(Ansicht, Dokumentationsstufe) - Pyramid erhält auch einen Hinweis von Django. Die Art und Weise, wie wir unsere Ansicht vertreten, unsere URL weiterleiten und die Dokumentationsebene ist sehr Django-artig.

Das Folgende sind die Merkmale des Pyramiden-Frameworks -

  • Es ist das am schnellsten bekannte Python-Webframework.

  • Es unterstützt kleine und große Projekte (warum neu schreiben, wenn Sie aus Ihrem kleinen Framework herauswachsen).

  • Es unterstützt Webapps mit einzelnen Dateien wie Mikroframeworks.

  • Es hat integrierte Sitzungen.

  • Es unterstützt Ereignisse ähnlich wie Plone / Zope.

  • Es bietet Transaktionsmanagement (falls Sie bereits bemerkt haben, dass wir Zope bereits verwendet haben).

Aufbau

Konfiguration sind die Einstellungen, die den Betrieb einer Anwendung beeinflussen. Es gibt zwei Möglichkeiten, eine Pyramidenanwendung zu konfigurieren: Imperative Konfiguration und deklarative Konfiguration.

Pyramidenkonfiguration unterstützt -

  • Imperative Konfiguration oder sogar das Überschreiben der auf Dekoratoren basierenden Konfigurationen

  • Erkennung von Konfigurationskonflikten (einschließlich mehr lokaler oder weniger lokaler Bestimmung)

  • Konfigurationserweiterung (in mehreren Apps enthalten)

  • Flexible Authentifizierungs- und Autorisierungsrichtlinien

  • Programmatische Überprüfung der Konfiguration (aktuellen Status der Routen anzeigen, um Navi zu generieren)

URL-Generierung

In Pyramid können wir URLs für Routen, Ressourcen und statische Assets generieren. Es ist einfach und flexibel, mit APIs zur URL-Generierung zu arbeiten. Durch das Generieren von URLs über die verschiedenen APIs von pyramid können Benutzer die Konfiguration beliebig ändern, ohne sich Sorgen machen zu müssen, dass ein Link zu einer Ihrer Webseiten unterbrochen wird.

Kurz gesagt, URL in der Pyramide -

  • unterstützt die URL-Generierung, um Änderungen an der App zu ermöglichen, die keine Links unterbrechen.

  • generiert URLs zu statischen Ressourcen, die sich entweder innerhalb oder außerhalb der Anwendung befinden.

  • unterstützt Routen und Traversal.

Ansichten

Eine der Hauptaufgaben von Pyramid besteht darin, eine aufrufbare Ansicht zu finden und aufzurufen, wenn eine Anforderung Ihre Anwendung erreicht. View Callables sind Codebits, die als Antwort auf eine in Ihrer Anwendung gestellte Anfrage etwas Interessantes bewirken.

Wenn Sie Ihre Ansichten Ihrem URL-Versand oder Python-Code zuordnen, kann es zu jeder Art von Anruf kommen. Ansichten können eine Funktionsdeklaration oder eine Instanz sein und als Ansicht in der Pyramide verwendet werden.

Einige wichtige Punkte zu Ansichten sind unten aufgeführt -

  • Ansichten werden von jedem aufrufbaren generiert.

  • Renderer-basierte Ansichten können einfach Wörterbücher zurückgeben (nicht erforderlich, um ein Objekt im Webby-Stil zurückzugeben).

  • Unterstützt mehrere Ansichten pro Route (GET vs. POST vs. HTTP-Header-Prüfung usw.).

  • Antwortadapter anzeigen (wenn Sie angeben möchten, wie Ansichtsrückgabewerte im Vergleich zu Antwortobjekten behandelt werden sollen).

Erweiterbarkeit

Pyramid wurde unter Berücksichtigung der Erweiterbarkeit entwickelt. Wenn ein Pyramidenentwickler beim Erstellen einer Anwendung bestimmte Einschränkungen berücksichtigt, sollte ein Dritter in der Lage sein, das Verhalten der Anwendung zu ändern, ohne den Quellcode ändern zu müssen. Das Verhalten einer Pyramidenanwendung, die bestimmte Einschränkungen erfüllt, kann ohne Änderung überschrieben oder erweitert werden. Es ist für flexible Bereitstellungen in mehreren Umgebungen (keine Singletons) konzipiert. Pyramid bietet Middleware-Unterstützung für Tweens (WSGI Middleware, wird jedoch im Kontext von Pyramid selbst ausgeführt).

Ausführen eines Hello, Pyramid-Programms

Das einfachste Programm, das wir nach der Installation des Pyramiden-Frameworks denken können, um zu überprüfen, ob alles einwandfrei funktioniert, ist die Ausführung eines einfachen Programms "Hallo, Welt" oder "Hallo, Pyramide".

Unten ist mein Pyramidenprogramm "Hallo, Pyramide" auf 8000 Portnummer -

Das obige einfache Beispiel ist einfach auszuführen. Speichern Sie dies als app.py (In diesem haben wir den Namen pyramid_helloW.py angegeben).

Das einfachste Programm ausführen: -

Als nächstes öffnen http://localhost:8000/in einem Browser, und Sie werden die Hallo, Pyramide! Nachricht wie folgt -

Das Folgende ist die Erklärung für den obigen Code -

Linie Nr. 1-3

Am Anfang der Datei stehen Importanweisungen. In der ersten Zeile wird die Funktion make_server importiert, mit der ein einfacher Webserver erstellt werden kann, wenn er an eine Anwendung übergeben wird. Die zweite und dritte Zeile importieren die Konfigurations- und Antwortfunktion aus der Pyramide. Diese Funktionen werden verwendet, um Details zu konfigurieren und Parameter für die Anwendung festzulegen bzw. auf Anforderungen zu antworten.

Linie Nr. 5-6

Jetzt haben wir eine Funktionsdefinition namens hello_world. Implementieren Sie den Ansichtscode, der die Antwort generiert. Eine Funktion, die die Anforderung einer Ansicht erfüllt, ist für das Rendern des Texts verantwortlich, der an die anfordernde Entität zurückgegeben wird. Im obigen Fall verwendet die aufgerufene Funktion die zuvor importierte Antwortfunktion. Dies gibt einen Wert zurück, der dem Client gegeben werden sollte.

Linie Nr. 8

if __name__ == '__main__': Python sagt: "Beginnen Sie hier, wenn Sie über die Befehlszeile ausgeführt werden", anstatt dieses Modul zu importieren.

Linie Nr. 9-11

In Zeile Nr. In 9 erstellen wir eine Variable namens config aus dem Objekt, das von der Konfiguratorfunktion erstellt wurde, die wir oben im Programm importiert haben. Die Zeilen 10 und 11 rufen die Methoden add_route und add_view dieses Objekts auf. Diese Methode wird verwendet, um eine Ansicht zu definieren, die von der Anwendung verwendet werden kann. Wie wir sehen können, übergeben wir die zuvor definierte Funktion hello_world. Hier wird diese Funktion tatsächlich als Ansicht integriert.

Linie Nr. 12-14

In diesem Fall erstellen wir die WSGI-Anwendung tatsächlich, indem wir die Methode make_wsgi_app des Konfigurationsobjekts aufrufen. Dabei werden die Attribute des Objekts verwendet, z. B. die von uns hinzugefügte Ansicht, um eine Anwendung zu erstellen. Diese Anwendung wird dann an die von uns importierte Funktion make_server übergeben, um ein Objekt zu erstellen, mit dem ein Webserver für unsere Anwendung gestartet werden kann. Die letzte Zeile startet diesen Server.

Unsere hello world applicationist eine der einfachsten und einfachsten Pyramidenanwendungen, die „zwingend“ konfiguriert wird. Dies ist unbedingt erforderlich, da uns bei der Ausführung von Konfigurationsaufgaben die volle Leistung von Python zur Verfügung steht.

Zusammenfassend ist Pyramid ein Open-Source-Python-Webframework mit einer großen und aktiven Community. Diese große Community trägt dazu bei, das Python-Webframework populär und relevant zu machen. Das Pyramid Web Framework vereinfacht und beschleunigt die Entwicklung von Webanwendungen durch die Bereitstellung einer Reihe robuster Funktionen und Tools.

In diesem Kapitel werden wir das Dash-Framework ausführlich diskutieren.

Dash ist ein Open-Source-Python-Framework, das zum Erstellen analytischer Webanwendungen verwendet wird. Es ist eine leistungsstarke Bibliothek, die die Entwicklung datengesteuerter Anwendungen vereinfacht. Dies ist besonders nützlich für Python-Datenwissenschaftler, die mit der Webentwicklung nicht sehr vertraut sind. Benutzer können mithilfe von Dash erstaunliche Dashboards in ihrem Browser erstellen.

Dash basiert auf Plotly.js, React und Flask und verknüpft moderne UI-Elemente wie Dropdowns, Schieberegler und Diagramme direkt mit Ihrem analytischen Python-Code.

Dash-Apps bestehen aus einem Flask-Server, der über JSTP-Pakete über HTTP-Anforderungen mit Front-End-React-Komponenten kommuniziert.

Dash-Anwendungen sind rein in Python geschrieben, daher ist KEIN HTML oder JavaScript erforderlich.

Dash Setup

Wenn Dash noch nicht in Ihrem Terminal installiert ist, installieren Sie die unten genannten Dash-Bibliotheken. Da sich diese Bibliotheken in der aktiven Entwicklung befinden, installieren und aktualisieren Sie sie dann regelmäßig. Python 2 und 3 werden ebenfalls unterstützt.

  • pip install dash == 0.23.1 # Das Kern-Dash-Backend
  • pip install dash-renderer == 0.13.0 # Das Dash-Frontend
  • pip install dash-html-components == 0.11.0 # HTML-Komponenten
  • pip install dash-core-components == 0.26.0 # Aufgeladene Komponenten
  • pip install plotly == 3.1.0 # Plotly-Grafikbibliothek

Um sicherzustellen, dass alles ordnungsgemäß funktioniert, haben wir hier eine einfache dashApp.py-Datei erstellt.

Dash- oder App-Layout

Dash-Apps bestehen aus zwei Teilen. Der erste Teil ist das „Layout“ der App, das im Wesentlichen beschreibt, wie die Anwendung aussieht. Der zweite Teil beschreibt die Interaktivität der Anwendung.

Kernkomponenten

Wir können das Layout mit dem erstellen dash_html_components und die dash_core_componentsBibliothek. Dash bietet Python-Klassen für alle visuellen Komponenten der Anwendung. Wir können auch unsere eigenen Komponenten mit JavaScript und React.js anpassen.

importiere dash_core_components als dcc

importiere dash_html_components als html

Die dash_html_components gelten für alle HTML-Tags, wobei die dash_core_components für die mit React.js erstellte Interaktivität vorgesehen sind.

Schreiben wir unter Verwendung der beiden oben genannten Bibliotheken einen Code wie unten angegeben -

app = dash.Dash()
app.layout = html.Div(children=[
   html.H1(children='Hello Dash'),
   html.Div(children='''Dash Framework: A web application framework for Python.''')

Und der entsprechende HTML-Code würde so aussehen -

<div>
   <h1> Hello Dash </h1>
   <div> Dash Framework: A web application framework for Python. </div>
</div>

Schreiben der Simple Dash App

Wir werden lernen, wie man ein einfaches Beispiel für einen Bindestrich mit der oben genannten Bibliothek in einer Datei schreibt dashApp.py.

# -*- coding: utf-8 -*-
import dash
import dash_core_components as dcc
import dash_html_components as html

app = dash.Dash()
app.layout = html.Div(children=[
   html.H1(children='Hello Dash'),
   html.Div(children='''Dash Framework: A web application framework for Python.'''),
	
   dcc.Graph(
      id='example-graph',
      figure={
         'data': [
            {'x': [1, 2, 3], 'y': [4, 1, 2], 'type': 'bar', 'name': 'Delhi'},
            {'x': [1, 2, 3], 'y': [2, 4, 5], 'type': 'bar', 'name': u'Mumbai'},
         ],
         'layout': {
            'title': 'Dash Data Visualization'
         }
      }
   )
])

if __name__ == '__main__':
   app.run_server(debug=True)

Ausführen der Dash-App

Beachten Sie beim Ausführen der Dash-App die folgenden Punkte.

(MyDjangoEnv) C: \ Benutzer \ rajesh \ Desktop \ MyDjango \ dash> python dashApp1.py

  • Serving Flask App "dashApp1" (verzögertes Laden)

  • Umwelt: Produktion

    WARNUNG: Verwenden Sie den Entwicklungsserver nicht in einer Produktionsumgebung.

    Verwenden Sie stattdessen einen Produktions-WSGI-Server.

  • Debug-Modus: Ein

  • Neustart mit stat

  • Debugger ist aktiv!

  • Debugger-PIN: 130-303-947

  • Laufen weiter http://127.0.0.1:8050/ (Drücken Sie STRG + C, um den Vorgang zu beenden.)

127.0.0.1 - - [12/Aug/2018 09:32:39] "GET / HTTP/1.1" 200 -
127.0.0.1 - - [12/Aug/2018 09:32:42] "GET /_dash-layout HTTP/1.1" 200 -
127.0.0.1 - - [12/Aug/2018 09:32:42] "GET /_dash-dependencies HTTP/1.1" 200 -
127.0.0.1 - - [12/Aug/2018 09:32:42] "GET /favicon.ico HTTP/1.1" 200 -
127.0.0.1 - - [12/Aug/2018 09:39:52] "GET /favicon.ico HTTP/1.1" 200 -

Besuch http:127.0.0.1:8050/in Ihrem Webbrowser. Sie sollten eine App sehen, die so aussieht.

Im obigen Programm sind einige wichtige Punkte zu beachten:

  • Das App-Layout besteht aus einem Baum von „Komponenten“ wie html.Div und dcc.Graph.

  • Die Bibliothek dash_html_components enthält eine Komponente für jedes HTML-Tag. Die Komponente html.H1 (children = 'Hello Dash') generiert in Ihrer Anwendung ein HTML-Element <h1> Hello Dash </ h1>.

  • Nicht alle Komponenten sind reines HTML. Die dash_core_components beschreiben übergeordnete Komponenten, die interaktiv sind und mit JavaScript, HTML und CSS über die React.js-Bibliothek generiert werden.

  • Jede Komponente wird vollständig durch Schlüsselwortattribute beschrieben. Dash ist deklarativ: Sie beschreiben Ihre Anwendung hauptsächlich anhand dieser Attribute.

  • Das Kindereigentum ist etwas Besonderes. Konventionell ist es immer das erste Attribut, was bedeutet, dass Sie es weglassen können.

  • Html.H1 (children = 'Hello Dash') ist dasselbe wie html.H1 ('Hello Dash').

  • Die Schriftarten in Ihrer Anwendung sehen etwas anders aus als hier angezeigt. Diese Anwendung verwendet ein benutzerdefiniertes CSS-Stylesheet, um die Standardstile der Elemente zu ändern. Ein benutzerdefinierter Schriftstil ist zulässig, aber ab sofort können wir die folgende URL oder eine beliebige URL Ihrer Wahl hinzufügen.

    app.css.append_css ({“external_url”:https://codepen.io/chriddyp/pen/bwLwgP.css}), damit Ihre Datei das gleiche Erscheinungsbild dieser Beispiele erhält.

Mehr über HTML

Die Bibliothek dash_html_components enthält eine Komponentenklasse für jedes HTML-Tag sowie Schlüsselwortargumente für alle HTML-Argumente.

Fügen wir den Inline-Stil der Komponenten in unseren vorherigen App-Text ein -

# -*- coding: utf-8 -*-
import dash
import dash_core_components as dcc
import dash_html_components as html

app = dash.Dash()
colors = {
   'background': '#87D653',
   'text': '#ff0033'
}

app.layout = html.Div(style={'backgroundColor': colors['background']}, children=[
   html.H1(
      children='Hello Dash',
      style={
         'textAlign': 'center',
         'color': colors['text']
      }
   ),
	
   html.Div(children='Dash: A web application framework for Python.', style={
      'textAlign': 'center',
      'color': colors['text']
   }),
	
   dcc.Graph(
      id='example-graph-2',

      figure={
         'data': [
            {'x': [1, 2, 3], 'y': [4, 1, 2], 'type': 'bar', 'name': 'Delhi'},
            {'x': [1, 2, 3], 'y': [2, 4, 5], 'type': 'bar', 'name': u'Mumbai'},
         ],
         'layout': {
            'plot_bgcolor': colors['background'],
            'paper_bgcolor': colors['background'],
            'font': {
               'color': colors['text']
            }
         }
      }
   )
])

if __name__ == '__main__':
   app.run_server(debug=True)

Im obigen Beispiel haben wir die Inline-Stile der Komponenten html.Div und html.H1 mit der style-Eigenschaft geändert.

Es wird in der Dash-Anwendung wie folgt gerendert:

Es gibt einige wichtige Unterschiede zwischen dash_html_components und HTML-Attributen -

  • Für die Stileigenschaft in Dash können Sie nur ein Wörterbuch angeben, während es sich in HTML um eine durch Semikolons getrennte Zeichenfolge handelt.

  • Stilwörterbuchschlüssel sind camelCased, also Textausrichtung ändert sich zu textalign.

  • ClassName in Dash ähnelt dem HTML-Klassenattribut.

  • Das erste Argument sind die untergeordneten Elemente des HTML-Tags, das über das untergeordnete Schlüsselwortargument angegeben wird.

Wiederverwendbare Komponenten

Durch Schreiben unseres Markups in Python können wir komplexe wiederverwendbare Komponenten wie Tabellen erstellen, ohne den Kontext oder die Sprache zu wechseln.

Unten finden Sie ein kurzes Beispiel, das aus dem Pandas-Datenrahmen eine „Tabelle“ generiert.

import dash
import dash_core_components as dcc
import dash_html_components as html
import pandas as pd

df = pd.read_csv(
   'https://gist.githubusercontent.com/chriddyp/'
   'c78bf172206ce24f77d6363a2d754b59/raw/'
   'c353e8ef842413cae56ae3920b8fd78468aa4cb2/'
   'usa-agricultural-exports-2011.csv')
	
def generate_table(dataframe, max_rows=10):
   return html.Table(
      # Header
      [html.Tr([html.Th(col) for col in dataframe.columns])] +
      # Body
      [html.Tr([
         html.Td(dataframe.iloc[i][col]) for col in dataframe.columns
      ]) for i in range(min(len(dataframe), max_rows))]
   )
	
app = dash.Dash()
app.layout = html.Div(children=[
   html.H4(children='US Agriculture Exports (2011)'),
   generate_table(df)
])

if __name__ == '__main__':
   app.run_server(debug=True)

Unsere Ausgabe wird so etwas wie -

Mehr zur Visualisierung

Die Bibliothek dash_core_components enthält eine Komponente namens Graph.

Graph rendert interaktive Datenvisualisierungen mithilfe der Open Source-JavaScript-Grafikbibliothek plotly.js. Plotly.js unterstützt rund 35 Diagrammtypen und rendert Diagramme sowohl in SVG in Vektorqualität als auch in WebGL mit hoher Leistung.

Unten sehen Sie ein Beispiel, das ein Streudiagramm aus einem Pandas-Datenrahmen erstellt.

import dash
import dash_core_components as dcc
import dash_html_components as html
import pandas as pd
import plotly.graph_objs as go

app = dash.Dash()

df = pd.read_csv(
   'https://gist.githubusercontent.com/chriddyp/' +
   '5d1ea79569ed194d432e56108a04d188/raw/' +
   'a9f9e8076b837d541398e999dcbac2b2826a81f8/'+
   'gdp-life-exp-2007.csv')
	
app.layout = html.Div([
   dcc.Graph(
      id='life-exp-vs-gdp',
      figure={
         'data': [
            go.Scatter(
               x=df[df['continent'] == i]['gdp per capita'],
               y=df[df['continent'] == i]['life expectancy'],
               text=df[df['continent'] == i]['country'],
               mode='markers',
               opacity=0.7,
               marker={
                  'size': 15,
                  'line': {'width': 0.5, 'color': 'white'}
               },
               name=i
            ) for i in df.continent.unique()
         ],
         'layout': go.Layout(
            xaxis={'type': 'log', 'title': 'GDP Per Capita'},
            yaxis={'title': 'Life Expectancy'},
            margin={'l': 40, 'b': 40, 't': 10, 'r': 10},
            legend={'x': 0, 'y': 1},
            hovermode='closest'
         )
      }
   )
])

if __name__ == '__main__':
   app.run_server()

Die Ausgabe des obigen Codes lautet wie folgt:

Diese Grafiken sind interaktiv und reagieren. Sie können mit der Maus über Punkte fahren, um deren Werte anzuzeigen, auf Legendenelemente klicken, um die Spuren umzuschalten, klicken und ziehen, um zu zoomen, die Umschalttaste gedrückt halten und klicken und ziehen, um zu schwenken.

Abschlag

Während Dash HTML-Aromen über die Bibliothek dash_html_components verfügbar macht, kann es mühsam sein, Ihre Kopie in HTML zu schreiben. Zum Schreiben von Textblöcken können Sie die Markdown-Komponente in der Bibliothek dash_core_components verwenden.

Kernkomponenten

Die dash_core_components enthalten eine Reihe übergeordneter Komponenten wie Dropdowns, Diagramme, Markdowns, Blöcke und vieles mehr.

Wie alle anderen Dash-Komponenten werden sie vollständig deklarativ beschrieben. Jede konfigurierbare Option ist als Schlüsselwortargument der Komponente verfügbar.

Unten sehen Sie das Beispiel mit einigen der verfügbaren Komponenten -

# -*- coding: utf-8 -*-
import dash
import dash_core_components as dcc
import dash_html_components as html

app = dash.Dash()

app.layout = html.Div([
   html.Label('Dropdown'),
   dcc.Dropdown(
      options=[
         {'label': 'New York City', 'value': 'NYC'},
         {'label': u'Montréal', 'value': 'MTL'},
         {'label': 'San Francisco', 'value': 'SF'}
      ],
      value='MTL'
   ),
	
   html.Label('Multi-Select Dropdown'),
   dcc.Dropdown(
      options=[
         {'label': 'New York City', 'value': 'NYC'},
         {'label': u'Montréal', 'value': 'MTL'},
         {'label': 'San Francisco', 'value': 'SF'}
      ],
      value=['MTL', 'SF'],
      multi=True
   ),
	
   html.Label('Radio Items'),
   dcc.RadioItems(
      options=[
         {'label': 'New York City', 'value': 'NYC'},
         {'label': u'Montréal', 'value': 'MTL'},
         {'label': 'San Francisco', 'value': 'SF'}
      ],
      value='MTL'
   ),
	
   html.Label('Checkboxes'),
   dcc.Checklist(
      options=[
         {'label': 'New York City', 'value': 'NYC'},
         {'label': u'Montréal', 'value': 'MTL'},
         {'label': 'San Francisco', 'value': 'SF'}
      ],
      values=['MTL', 'SF']
   ),

   html.Label('Text Input'),
   dcc.Input(value='MTL', type='text'),
	
   html.Label('Slider'),
   dcc.Slider(
      min=0,
      max=9,
      marks={i: 'Label {}'.format(i) if i == 1 else str(i) for i in range(1, 6)},
      value=5,
   ),
], style={'columnCount': 2})

if __name__ == '__main__':
   app.run_server(debug=True)

Die Ausgabe des obigen Programms ist wie folgt:

Hilfe anrufen

Dash-Komponenten sind deklarativ. Jeder konfigurierbare Aspekt dieser Komponenten wird während der Installation als Schlüsselwortargument festgelegt. Sie können die Hilfe in Ihrer Python-Konsole für eine der Komponenten aufrufen, um mehr über eine Komponente und ihre verfügbaren Argumente zu erfahren. Einige von ihnen sind unten angegeben -

>>> help(dcc.Dropdown)
Help on class Dropdown in module builtins:
class Dropdown(dash.development.base_component.Component)
| A Dropdown component.
| Dropdown is an interactive dropdown element for selecting one or more

| items.
| The values and labels of the dropdown items are specified in the `options`
| property and the selected item(s) are specified with the `value` property.
|
| Use a dropdown when you have many options (more than 5) or when you are
| constrained for space. Otherwise, you can use RadioItems or a Checklist,
| which have the benefit of showing the users all of the items at once.
|
| Keyword arguments:
| - id (string; optional)
| - options (list; optional): An array of options
| - value (string | list; optional): The value of the input. If `multi` is false (the default)
-- More --

Zusammenfassend beschreibt das Layout einer Dash-App, wie die App aussieht. Das Layout ist ein hierarchischer Baum von Komponenten. Die Bibliothek dash_html_components bietet Klassen für alle HTML-Tags und Schlüsselwortargumente und beschreibt die HTML-Attribute wie style, className und id. Die Bibliothek dash_core_components generiert übergeordnete Komponenten wie Steuerelemente und Diagramme.

Die Welt der Python-Webframeworks bietet viele Möglichkeiten. Einige der wichtigsten zu berücksichtigenden Frameworks sind Django, Flask, Bottle, Diesel, Web2py, Pyramid, Falcon, Pecan usw., die um den Mindshare der Entwickler konkurrieren. Frameworks wie Pyramid, Django, Web2py und Flask sind mit ihrer Liste von Vor- und Nachteilen ideal. Es ist schwierig, nur eine für Ihr Projekt auszuwählen.

Dash wurde vollständig für unterschiedliche Anforderungen entwickelt. Als Entwickler möchten Sie die Anzahl der Optionen auf die reduzieren, mit denen Sie Ihr Projekt pünktlich und perfekt abschließen können.

Wenn wir Flask-, Pyramid- und Django-Frameworks vergleichen, ist Flask ein Mikro-Framework, das hauptsächlich auf kleine Anwendungen mit einfacheren Anforderungen ausgerichtet ist, während Pyramid und Django beide auf größere Anwendungen ausgerichtet sind. Pyramid wurde mit Blick auf Flexibilität und Freiheit gebaut, sodass der Entwickler die richtigen Tools für das Projekt hat. Im Falle einer Pyramide kann der Entwickler die Datenbank, die URL-Struktur, den Vorlagenstil und mehr frei wählen. Django enthält jedoch alle Batterien, die eine Webanwendung benötigt. Daher müssen wir nur Django installieren und mit der Arbeit beginnen.

Django wird mit einem ORM geliefert, während Pyramid und Flask es dem Entwickler überlassen, zu entscheiden, wie (oder ob) ihre Daten gespeichert werden sollen. Im Allgemeinen ist SQLAlchemy das bei weitem häufigste ORM für Nicht-Django-Webanwendungen. Andere Optionen können jedoch DjangoDB, MongoDB, LevelDB und SQLite sein.

Als Entwickler muss ich für mein Projekt zwischen Django und Web2py wählen. Ich muss eine Vorstellung von den Vorteilen und Einschränkungen der Frameworks haben. Vergleichen wir also Django und Web2py -

Django

Die Gemeinde Django ist ein großes Plus. Für einen Entwickler bedeutet dies tatsächlich, dass der Ressourcenreichtum größer wird. Konkret geht es um -

  • Documentation
  • Open Source Ressourcen
  • Unterstützung für Apps von Drittanbietern
  • Bereitstellungsunterstützung
  • IRC-Kanäle mit hilfreichen Entwicklern

Django hat eine sehr große Community von Entwicklungsteams und Dokumentationen. Es ist das richtige Framework, wenn es um das Schreiben eines komplexen Backends geht, da es viele Apps von Drittanbietern bietet, mit denen Sie Dinge wie Benutzerlogik (Anmeldung, Authentifizierung), asynchrone Aufgaben, API-Erstellung, Blogs usw. automatisieren können.

Web2py

Web2py eignet sich gut für die schnelle Entwicklung einfacher Web-Apps oder http-Server. Im Folgenden finden Sie einige der Vor- und Nachteile von web2py.

Vorteile von Web2py

Im Folgenden sind einige der Vorteile des Web2py-Frameworks aufgeführt:

  • Web2py ist im Vergleich zu Django und Flask ein potenzielles Framework in Bezug auf Geschwindigkeit und Einfachheit der Entwicklung. Da Web2py eine Python-basierte Vorlagensprache verwendet, können Python-Entwickler sofort mit dem Schreiben von Code beginnen, nachdem sie die Grundlagen des Schreibens von Vorlagen als Ansichten verstanden haben.

  • Web2py kann Python-kompilierten Code als Optimierung ausführen, um die Laufzeit zu verkürzen und Ihnen zu ermöglichen, Ihren Code kompiliert zu verteilen.

Einschränkungen von Web2py

Im Folgenden sind einige der Einschränkungen des Frameworks aufgeführt:

  • Web2py unterstützt Doctests, jedoch keine Unit-Tests. Jetzt sind Doktrinen aufgrund ihres begrenzten Umfangs nicht die optimale Wahl.

  • Es gibt keine Unterscheidung zwischen Produktions- und Entwicklungsmodus. Im Falle einer Ausnahme wird das Ticket ständig generiert und Sie müssen zum Ticket navigieren, um den Fehler zu überprüfen. Dies kann im Falle eines Produktionsservers hilfreich sein, ist jedoch in der Entwicklungsumgebung schwierig, da Entwickler den Fehler wirklich sofort erkennen müssen, anstatt die Ticketnummer zu überprüfen.

  • Web2py verfügt über eine gute Datenbankabstraktionsschicht (DAL), mit der Sie viele Arten von Datenbankmodulen abstrahieren können, aber es fehlt leistungsfähiges ORM. Wenn Sie mit einem relativ großen Modell arbeiten, wird Ihr Code durch alle verschachtelten Definitionen und Attribute verstreut, was die Sache kompliziert macht.

  • Wir können keine Standard-Python-Entwicklungstools ohne Änderungen verwenden, da web2py eine wirklich schlechte IDE-Unterstützung bietet.

Das Django und Web2py Framework sind Full-Stack-Frameworks. Dies bedeutet, dass sie den gesamten erforderlichen Code bereitstellen - von Formulargeneratoren bis hin zu Vorlagenlayouts und Formularvalidierung - und dass Sie die Dinge entsprechend Ihren spezifischen Anforderungen schreiben können.

Wenn Sie jedoch mit Nicht-Stack-Frameworks wie Flask und Pyramid eine Website mit vollem Funktionsumfang erstellen möchten, müssen Sie selbst viel Code und zusätzliche Bits hinzufügen. Dies erfordert viel Geschick und Zeit.

Strich

Dash wurde vollständig für die spezifische Aufgabe entwickelt, ein reaktives Framework für Dashboards zu erstellen. Dash by Plotly ist eine großartige Möglichkeit für den Python-Entwickler, interaktive Web-Apps zu erstellen, ohne Javascript und die Front-End-Webentwicklung lernen zu müssen. Dash basiert auf Flask, Plotly.js, React und React Js.

Es gibt keinen Vergleich zwischen Dash und anderen Frameworks (oben erwähnt), da sie zu verschiedenen Kategorien von Frameworks gehören. Im Folgenden sind einige Gründe aufgeführt, warum Sie Dash anderen interaktiven Dashboard-Frameworks (Jupiter Dashboards, Matplotlib und andere) vorziehen sollten:

  • Mit nur 50 Codezeilen können Sie eine einfache Dash-App „Hallo Welt“ schreiben, da Dash nur sehr wenig Boilerplater benötigt.

  • Ganze Dash-Apps sind in Python-Sprache geschrieben, der weltweit am meisten bevorzugten Sprache.

  • In Ihrem eigenen Python-Code können Sie interaktive Dash-Komponenten wie Dropdown, Texteingaben, Schieberegler und Diagramme mit reaktiven Dash-Rückrufen binden.

  • Komplizierte Benutzeroberflächen in Dash-Apps können mehrere Eingaben, mehrere Ausgaben und Eingaben haben, die von anderen Eingaben abhängen.

  • Gleichzeitig können mehrere Benutzer an Dash-Apps arbeiten.

  • Zum Erstellen eigener Dash-Komponenten mit React verwendet dash React.js zum Rendern von Komponenten und enthält ein Plugin-System.

  • Entwickler oder Autoren können Dash-Apps schreiben, die auf das Klicken, Bewegen oder Auswählen von Punkten im Diagramm reagieren, da die Diagrammkomponenten von Dash interaktiv sind.

Fazit

Wir können daraus schließen, dass die Auswahl des richtigen Frameworks aus vielen verfügbaren Python-Frameworks ausschließlich von der Art des Projekts, der Komplexität, dem Projekt auf Klein- oder Unternehmensebene, der Art der verfügbaren Community-Unterstützung oder der verfügbaren Online-Ressource, der Skalierbarkeit, der Sicherheit usw. abhängt.

Die oben genannten Python-Frameworks sind die besten ihrer Klasse, haben jedoch ihre eigenen Vor- und Nachteile (abhängig von den Projektanforderungen). Eine Art von Framework ist also nicht für alle Arten von Projekten geeignet.