Evgenii Legotckoi
Evgenii Legotckoi16. Mai 2023 15:52

Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung

Auf dieser Website und einigen anderen Projekten verwende ich aktiv Markdown, um Text zu schreiben und daraus dann HTML-Code zu generieren. Und am Ende habe ich ein paar Erweiterungen geschrieben, die bestimmte Funktionen ausführen, was die Unterstützung für die Generierung von HTML-Code in meinen Projekten etwas erleichtert.

In einem der Projekte werden beispielsweise Bilder zum Text hinzugefügt, der der Site hinzugefügt und an den Beitrag angehängt wird. Dementsprechend haben Bilder eine bestimmte URL, an die Nginx dieses Bild sendet. Aber ich habe dafür gesorgt, dass der Markdown-Bildeinbettungscode für Bilder, die auf die Website hochgeladen werden, einfacher aussieht.

Beschreibung des Bildeinbettungscodes

Das heißt, der Bildeinfügungscode sieht in diesem Fall so aus

![](e272ed2bca9e46e8b017c20eddd1e5b2.webp)

In diesem Code gibt es nur den Namen der Bilddatei e272ed2bca9e46e8b017c20eddd1e5b2.webp . In dem Projekt, in dem dies implementiert ist, werden alle Bilder mit einem eindeutigen generierten Namen mithilfe von uuid in ein Verzeichnis geladen, und das Bild wird komprimiert und in das WEBP-Format konvertiert. Weitere Informationen hierzu finden Sie im Artikel So konvertieren Sie ein Bild beim Speichern in einem ImageField in das WEBP-Format .

Wenn also Bilder an einen Beitrag angehängt werden, werden sie in diesem Projekt als Galerie unter dem Text angezeigt, können aber auch innerhalb des Beitragstextes hinzugefügt werden. Um Benutzer jedoch nicht mit einer langen URL zum Bild im Markdown-Markup zu verwirren und auch die weitere mögliche Änderung von Bildpfaden zu vereinfachen, wurde eine Funktion implementiert, um aus diesem vereinfachten Bildcode ein HTML-IMG-Tag zu generieren.

Python-Markdown-Erweiterung hinzugefügt

Generieren Sie HTML-Text mit Python-Markdown

Zur Generierung des HTML wird das Paket Python-Markdown verwendet. Der Generierungscode könnte so aussehen:

def generate_html(markdown_text):
    return markdown.markdown(
                markdown_text,
                extensions=['markdown.extensions.attr_list',
                            'markdown.extensions.tables',
                            'markdown.extensions.fenced_code',
                            'markdown.extensions.nl2br',
                            'markdown.extensions.toc'],
                output_format='html5'
            )

Wie Sie sehen, ist es beim Generieren möglich, Erweiterungen aufzuzählen, die das Ergebnis der Codegenerierung beeinflussen können. In diesen Erweiterungen werden wir unsere Erweiterung hinzufügen.

Erweiterung hinzufügen

Nehmen wir an, wir haben in einem Django-Projekt eine App namens Core. Erstellen wir darin ein Verzeichnis extensions mit einer Datei __init__.py , die das Verzeichnis als Paket initialisiert, sowie einer Datei mit dem Namen der Erweiterung. Es sollte so aussehen.

  • core/
    • extensions/
      • __init__.py
      • image.py

Image.py-Datei

Fügen wir nun den Inhalt der Datei image.py hinzu.

# -*- coding: utf-8 -*-

import markdown
from markdown.util import etree


class ImageExtension(markdown.Extension):

    def add_inline(self, md, name, klass, re):
        pattern = klass(re)
        pattern.md = md
        pattern.ext = self
        md.inlinePatterns.add(name, pattern, "<reference")

    def extendMarkdown(self, md, md_globals):
        self.add_inline(md, 'internal_image', InternalImage, r'!\[\]\((?P<internal_image>[a-zA-Z0-9]+).webp\)')


class InternalImage(markdown.inlinepatterns.Pattern):

    def handleMatch(self, m):
        return render_image(m.group('internal_image'))


def render_image(internal_image_name):
    img = etree.Element('img')
    img.set('src', '/media/photos/{}.webp'.format(internal_image_name))
    img.set('class', 'd-block mx-auto mw-100 mvh-75')
    return img


def makeExtension(**kwargs):
    return ImageExtension(**kwargs)

In diesem Fall erstellen wir eine ImageExtension -Erweiterung, die das Markdown -Markup mithilfe der InternalImage -Vorlage erweitert.
Dieses Muster wird auf alle Bild-Tags angewendet, die mit dem regulären Ausdruck übereinstimmen, der an die Methode add_inline übergeben wird, die das Muster letztendlich mit dem Markdown-Code-Handler zur Liste der Muster hinzufügt.

Die Funktion makeExtension wird unter der Haube von Python-Markdown aufgerufen und registriert die Erweiterung.

Abschluss

Als letztes Wort fügen wir Ihre neue Erweiterung zur Generierung Ihres HTML-Codes hinzu.

def generate_html(markdown_text):
    return markdown.markdown(
                markdown_text,
                extensions=['core.extensions.image',
                            'markdown.extensions.attr_list',
                            'markdown.extensions.tables',
                            'markdown.extensions.fenced_code',
                            'markdown.extensions.nl2br',
                            'markdown.extensions.toc'],
                output_format='html5'
            )
Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

ИМ
  • 5. Oktober 2024 07:51
  • (bearbeitet)

Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку:

<ul>
    <li></li>
    <li></li>
</ul>

подменять ее на свою типа:

<ul class='my_ul_class'>
    <li class='my_li_class'></li>
    <li class='my_li_class'></li>
</ul>

Kommentare

Nur autorisierte Benutzer können Kommentare posten.
Bitte Anmelden oder Registrieren
Letzte Kommentare
ИМ
Игорь Максимов5. Oktober 2024 07:51
Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
d
dblas55. Juli 2024 11:02
QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
k
kmssr8. Februar 2024 18:43
Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
EVA
EVA25. Dezember 2023 10:30
Boost - statisches Verknüpfen im CMake-Projekt unter Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
Jetzt im Forum diskutieren
J
JacobFib17. Oktober 2024 03:27
добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
JW
Jhon Wick1. Oktober 2024 15:52
Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
КГ
Кирилл Гусарев27. September 2024 09:09
Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
F
Fynjy22. Juli 2024 04:15
при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

Folgen Sie uns in sozialen Netzwerken