Mit dem folgenden Befehl können Sie ein Back-End auswählen und anschließend jeden Unterbaum der obersten Ebene in eine separate Datei exportieren:
(defun org-export-all (backend)
"Export all subtrees that are *not* tagged with :noexport: to
separate files.
Note that subtrees must have the :EXPORT_FILE_NAME: property set
to a unique value for this to work properly."
(interactive "sEnter backend: ")
(let ((fn (cond ((equal backend "html") 'org-html-export-to-html)
((equal backend "latex") 'org-latex-export-to-latex)
((equal backend "pdf") 'org-latex-export-to-pdf))))
(save-excursion
(set-mark (point-min))
(goto-char (point-max))
(org-map-entries (lambda () (funcall fn nil t)) "-noexport" 'region-start-level))))
Dies unterstützt derzeit den Export von HTML ( html
), LaTeX ( latex
) und PDF ( pdf
). Sie können Unterstützung für mehr Back-Ends hinzufügen, indem Sie weitere Klauseln hinzufügen cond
.
Wie in der Dokumentation angegeben, müssen Sie für jede Unterstruktur die :EXPORT_FILE_NAME:
Eigenschaft auf den Dateinamen festlegen, in den sie exportiert werden soll. (Weitere Optionen siehe unten.)
Der Name der Exportdatei wird automatisch aus dem Überschriftentext generiert
Wenn Sie nicht :EXPORT_FILE_NAME:
jeder Überschrift der obersten Ebene Eigenschaften hinzufügen möchten , können Sie org-export-all
den Dateinamen so ändern , dass er automatisch aus z. B. dem Überschriftentext generiert wird. Diese Einstellung wird :EXPORT_FILE_NAME:
beim Export vorübergehend festgelegt :
(defun org-export-all (backend)
"Export all subtrees that are *not* tagged with :noexport: to
separate files.
Subtrees that do not have the :EXPORT_FILE_NAME: property set
are exported to a filename derived from the headline text."
(interactive "sEnter backend: ")
(let ((fn (cond ((equal backend "html") 'org-html-export-to-html)
((equal backend "latex") 'org-latex-export-to-latex)
((equal backend "pdf") 'org-latex-export-to-pdf)))
(modifiedp (buffer-modified-p)))
(save-excursion
(set-mark (point-min))
(goto-char (point-max))
(org-map-entries
(lambda ()
(let ((export-file (org-entry-get (point) "EXPORT_FILE_NAME")))
(unless export-file
(org-set-property
"EXPORT_FILE_NAME"
(replace-regexp-in-string " " "_" (nth 4 (org-heading-components)))))
(funcall fn nil t)
(unless export-file (org-delete-property "EXPORT_FILE_NAME"))
(set-buffer-modified-p modifiedp)))
"-noexport" 'region-start-level))))
Diese Funktion generiert den Exportdateinamen, indem Leerzeichen im Überschriftentext durch "_" ersetzt werden. Wenn Sie den Dateinamen auf eine andere Weise generieren möchten, ändern Sie das replace-regexp-in-string
Sexp nach Ihren Wünschen.
Die Erzeugung :EXPORT_FILE_NAME:
bei der Einstellung:CUSTOM_ID:
Mit den folgenden Ratschlägen org-set-property
wird automatisch ein geeigneter Wert für festgelegt, :EXPORT_FILE_NAME:
wenn Sie :CUSTOM_ID:
:
(defadvice org-set-property (after set-export-file-name
(property value) activate compile)
(when (equal org-last-set-property "CUSTOM_ID")
(let ((export-file-name
(concat (org-entry-get nil "CUSTOM_ID")
"-"
(replace-regexp-in-string " " "-" (downcase (org-get-heading t t))))))
(org-entry-put nil "EXPORT_FILE_NAME" export-file-name))))
Beachten Sie, dass hierdurch keine Dateierweiterung zum Wert von hinzugefügt wird, dies :EXPORT_FILE_NAME:
jedoch keine Rolle spielt, da beim Export in ein bestimmtes Back-End org-mode
automatisch die richtige Erweiterung für die resultierenden Dateien ausgewählt wird .
Zusätzliche Information
Aktualisieren vorhandener Teilbäume in großen Mengen
Wenn Sie über eine große Anzahl vorhandener Unterstrukturen verfügen, für die Sie die :EXPORT_FILE_NAME:
Eigenschaft festlegen müssen , können Sie ein Tastaturmakro verwenden . Positionieren Sie den Punkt auf dem ersten Teilbaum und gehen Sie dann wie folgt vor:
F3
... um die Aufnahme zu starten.
C-c C-x p CUSTOM_ID
RET RET
... um Emacs :EXPORT_FILE_NAME:
basierend auf :CUSTOM_ID:
.
C-c C-f
... um zur nächsten übergeordneten Überschrift zu gelangen.
F4
... um die Aufnahme zu stoppen.
Drücken Sie, um das Makro für den nächsten Teilbaum zu wiederholen F4. Um das Makro für alle verbleibenden Teilbäume zu wiederholen , drücken Sie M-0 F4(das ist eine Null).
Speichern von Makros für zukünftige Sitzungen
Standardmäßig werden Tastaturmakros nicht sitzungsübergreifend gespeichert. Gehen Sie folgendermaßen vor, um das Makro zur späteren Verwendung in Ihrer Init-Datei zu speichern:
Nennen Sie das Makro:
M-x name-last-kbd-macro
RET org-set-export-file-name
RET
Suchen Sie Ihre Init-Datei und verschieben Sie sie an eine Stelle, an der Sie das Makro einfügen möchten.
Fügen Sie das Makro ein:
M-x insert-kbd-macro
RET org-set-export-file-name
RET
Emacs fügt an dieser Stelle den folgenden Code ein:
(fset 'org-set-export-file-name
"\C-c\C-xpCUSTOM_ID\C-m\C-m\C-c\C-f")
Wenn Sie stark genug blinzeln, können Sie sehen, dass das zweite Argument fset
die Tastenfolge enthält, die Sie beim Aufzeichnen des Makros gedrückt haben :)
(Optional) Die besten Ergebnisse erzielen Sie, wenn Sie org-set-export-file-name
an einen Schlüssel binden :
(define-key org-mode-map (kbd "<f6>") 'org-set-export-file-name)
Speichern.
:EXPORT_FILE_NAME:
Eigenschaften:CUSTOM_ID:+heading-title-lowercased
für jede Überschrift programmgesteuert festgelegt werden ?