組織モードでHTMLペーパーをフォーマットする


11

HTMLエクスポート中のOrg-modeのデフォルトは、ページの下部にあるポストアンブルに著者を置くことです。

しかし、私はタイトルと要約の間に著者と一緒にドキュメントのような論文をエクスポートしたいと思います。どういうわけかタイトルの後に著者を置くことは可能ですか?

そして、要約を要約としてラベル付けすることは可能ですか?区切り文字を使用しました

#+BEGIN_abstract
...
#+END_abstract

テキストを抽象としてマークしますが、通常の段落と同じようにレンダリングされます(インデントのようなブロック引用符はありません)。アブストラクトとローカライズされたラベルの正しいインデントを取得することは可能ですか?


2
抽象要件については、cssを使用します。 ...としてラップされ<div class="abstract"><p>...</p></div>ます。LaTeXのようなタイトルを付けるには、バグレポートに記入する必要があります。ここでは、マクロ{{{AUTHOR}}}とスニペット@@html:whatever@@を使用して、必要なものを作成します。
rasmus

回答:


10

多分このようなもの(LaTeXとHTMLでテストされています)

#+TITLE: An Orged Paper
#+AUTHOR: Rasmus
#+DATE: A Dark Day for Science 

#+RESULTS: html-header

#+begin_abstract
#+begin_center
{{{html-only(*Abstract*)}}}
#+end_center
my long abstract that is longer than one line. my long abstract that is longer than one line.
#+end_abstract
#+toc: headlines
* Introduction
Please read my paper!
* Data
~{0,1}~
* Conclusion
Something deep and profound

{{{html-only(------------)}}}
* styles                                                           :noexport:
#+HTML_HEAD_EXTRA: <style type="text/css">
#+HTML_HEAD_EXTRA: <!--
#+HTML_HEAD_EXTRA:   .header_title {font-size: 2em; font-weight: bold;}
#+HTML_HEAD_EXTRA:   .header_author {font-size: 1.5em; font-weight: bold;text-align:center;}
#+HTML_HEAD_EXTRA:   .header_date {text-align:center;}
#+HTML_HEAD_EXTRA:   .header_date .timestamp {font-size:1em; color:#000000;}
#+HTML_HEAD_EXTRA:   .abstract {max-width: 30em; margin-left: auto; margin-right: auto;}
#+HTML_HEAD_EXTRA: -->
#+HTML_HEAD_EXTRA: </style>

#+OPTIONS: toc:nil

#+MACRO: html-only (eval (if (org-export-derived-backend-p org-export-current-backend 'html) "$1" ""))

#+NAME: html-header
#+BEGIN_SRC emacs-lisp :results raw :exports (if (org-export-derived-backend-p org-export-current-backend 'html) "results" "none")
  "#+begin_header
  ,#+begin_header_author
  {{{AUTHOR}}}
  ,#+end_header_author
  ,#+begin_header_date
  {{{DATE}}}
  ,#+end_header_date
  ,#+end_header
"
#+END_SRC

を使用してhtml-header生成することもできorg-html-preambleます。また、from org 8.3 org-latex-title-commandを使用してタイトルをフォーマット文字列としてカスタマイズできることにも注意してください。


2

ソースコードを見てください、これを行うオプションがないようです。

あなたが本当に何を望んでいるかはわかりません。可能な2つの方法を提供してください。

  1. #+BEGIN_HTML ... #+END_HTML必要なものを書き込むためにブロックを追加するだけです。(その中に書かれたコンテンツは完全にHTMLとして扱われます。)しかし、#+OPTIONS: toc: nilTOCを無効にするために追加する必要があるかもしれません。そうしないと著者がTOCの下に置かれます。

  2. エクスポート関数を再定義し、必要なことを実行します(50行目から52行目を通知)。構成(require 'ox-html)ファイルの後に次のコードを挿入するだけです。

      (defun org-html-template (contents info)
        "Return complete document string after HTML conversion.
      CONTENTS is the transcoded contents string.  INFO is a plist
      holding export options."
        (concat
         (when (and (not (org-html-html5-p info)) (org-html-xhtml-p info))
           (let ((decl (or (and (stringp org-html-xml-declaration)
                  org-html-xml-declaration)
                 (cdr (assoc (plist-get info :html-extension)
                     org-html-xml-declaration))
                 (cdr (assoc "html" org-html-xml-declaration))
    
                 "")))
             (when (not (or (eq nil decl) (string= "" decl)))
         (format "%s\n"
             (format decl
                 (or (and org-html-coding-system
                      (fboundp 'coding-system-get)
                      (coding-system-get org-html-coding-system 'mime-charset))
                     "iso-8859-1"))))))
         (org-html-doctype info)
         "\n"
         (concat "<html"
           (when (org-html-xhtml-p info)
             (format
              " xmlns=\"http://www.w3.org/1999/xhtml\" lang=\"%s\" xml:lang=\"%s\""
              (plist-get info :language) (plist-get info :language)))
           ">\n")
         "<head>\n"
         (org-html--build-meta-info info)
         (org-html--build-head info)
         (org-html--build-mathjax-config info)
         "</head>\n"
         "<body>\n"
         (let ((link-up (org-trim (plist-get info :html-link-up)))
         (link-home (org-trim (plist-get info :html-link-home))))
           (unless (and (string= link-up "") (string= link-home ""))
             (format org-html-home/up-format
               (or link-up link-home)
               (or link-home link-up))))
         ;; Preamble.
         (org-html--build-pre/postamble 'preamble info)
         ;; Document contents.
         (format "<%s id=\"%s\">\n"
           (nth 1 (assq 'content org-html-divs))
           (nth 2 (assq 'content org-html-divs)))
         ;; Document title.
         (let ((title (plist-get info :title)))
           (format "<h1 class=\"title\">%s</h1>\n" (org-export-data (or title "") info)))
         ;; Author
         (let ((author (plist-get info :author)))
           (format "<h2 class=\"author\">%s</h2>\n" (org-export-data (or author "") info)))
         contents
         (format "</%s>\n"
           (nth 1 (assq 'content org-html-divs)))
         ;; Postamble.
         (org-html--build-pre/postamble 'postamble info)
         ;; Closing document.
         "</body>\n</html>"))        
    

3
これは絶対に間違った方法です!! できれば、派生org-export-define-derived-backendテンプレートを作成し、新しいテンプレートを表示してに追加する必要があります:translate-alist。具体的な例についてはox-beamer.elox-koma-script.elを確認してくださいox-s5.el
rasmus

1

私がこれで遭遇した最も難しい問題は、さまざまなセクションの条件付きスタイリングとさまざまなセクションの条件付き番号付けです。これは、これらの問題の両方の解決策です。

これが私の論文です:

#+TITLE: Complex Tracking of Awesome Things
#+AUTHOR: Bastibe
#+INCLUDE: style.org

* Abstract
:PROPERTIES:
:NUMBERS: no
:HTML_CONTAINER_CLASS: abstract
:END:

Lorem ipsum dolor sit amet...

* Introduction
:PROPERTIES:
:NUMBERS: no
:END:

* Methodology

* Results

* Conclusion

* Acknowledgements
:PROPERTIES:
:NUMBERS:  no
:END:

まず、これには、いくつかの追加オプションを含むorgファイルが含まれます。style.org上記のこのファイルは、カスタムスタイルシートをロードするためのHTMLエクスポートを設定し、いくつかのLaTeXオプションを設定します。LaTeXにエクスポートしない場合、それらは必要ありません。

#+LANGUAGE: en
#+OPTIONS: tags:nil html-postamble:nil # toc:nil
#+STARTUP: nofold hideblocks
#+BIND: org-latex-title-command ""

#+HTML_MATHJAX: path:"MathJax/MathJax.js"
#+HTML_HEAD: <link rel="stylesheet" type="text/css" href="style.css" />

#+LATEX_CLASS: article
#+LATEX_CLASS_OPTIONS: [a4paper, 12pt]
#+LATEX_HEADER: \usepackage{setspace}
#+LATEX_HEADER: \onehalfspacing
#+LATEX_HEADER: \usepackage{fontspec}
#+LATEX_HEADER: \setmainfont{Cambria}
#+LATEX_HEADER: \setmonofont{PragmataPro}
#+LATEX_HEADER: \usepackage{polyglossia}
#+LATEX_HEADER: \setdefaultlanguage{english}
#+LATEX_HEADER: \usepackage[a4paper, scale=0.8]{geometry}
#+LATEX_HEADER: \usepackage{amsmath}
#+LATEX_HEADER: \usepackage{units}
#+LATEX_HEADER: \usepackage{titling}
#+LATEX_HEADER: \usepackage{listings}
#+LATEX_HEADER: \lstset{basicstyle=\ttfamily\footnotesize,showstringspaces=false}
#+LATEX_HEADER: \usepackage[hang]{caption}

これを紙のようなHTMLとしてレンダリングするには、少しCSSで十分です(以下に保存されていstyle.cssます:

#content {
    max-width: 80ex;
    position: relative;
    margin: 5px auto;
    font-family: Cambria;
    text-align: justify;
    -moz-hyphens: auto;
}

.abstract {
    max-width: 65ex;
    margin: 5px auto;
    margin-top: 4em;
    margin-bottom: 4em;
    content: none;
}

p {
    text-indent: 5ex;
    margin-bottom: 0;
    margin-top: 0;
}

ただし、セクション番号は間違っています。組織モードでは、すべてのセクションに番号を付けることも、なしにすることもできます。論文は通常、本文のセクションに番号が必要ですが、要約と要約は必要ありません。次のコードは、Orgが通常のセクションの前に数値を配置するようにします:NUMBERS: noが、プロパティが設定されている場合は数値を抑制します。

(defun headline-numbering-filter (data backend info)
  "No numbering in headlines that have a property :numbers: no"
  (let* ((beg (next-property-change 0 data))
         (headline (if beg (get-text-property beg :parent data))))
    (if (string= (org-element-property :NUMBERS headline) "no")
        (cond ((eq backend 'latex)
               (replace-regexp-in-string
                "\\(part\\|chapter\\|\\(?:sub\\)*section\\|\\(?:sub\\)?paragraph\\)"
                "\\1*" data nil nil 1))
              ((eq backend 'html)
               (replace-regexp-in-string
                "\\(<h[1-6]\\)\\([^>]*>\\)"
                "\\1 class=\"nonumber\"\\2" data nil nil)))
      data)))

(setq org-export-filter-headline-functions '(headline-numbering-filter))

これはLaTeXエクスポートではうまく機能しますが、HTMLエクスポートでは機能しません。最近のCSSでは、ブラウザーが番号付けを行うことができます(に追加style.css):

/* do not show section numbers */
span.section-number-2 { display: none; }
span.section-number-3 { display: none; }
span.section-number-4 { display: none; }
span.section-number-5 { display: none; }
span.section-number-6 { display: none; }

/* use LaTeX-style names for the counters */
h1 { counter-reset: section; }
h2 { counter-reset: subsection; }
h3 { counter-reset: subsubsection; }
h4 { counter-reset: paragraph; }
h5 { counter-reset: subparagraph; }

.nonumber::before { content: none; }

h2::before {
    content: counter(section) " ";
    counter-increment: section;
}

h3::before {
    content: counter(section) "." counter(subsection) " ";
    counter-increment: subsection;
}

h4::before {
    content: counter(section) "." counter(subsection) "." counter(subsubsection) " ";
    counter-increment: subsubsection;
}

h5::before {
    content: counter(section) "." counter(subsection) "." counter(subsubsection) "." counter(paragraph) " ";
    counter-increment: paragraph;
}

h6::before {
    content: counter(section) "." counter(subsection) "." counter(subsubsection) "." counter(paragraph) "." counter(subparagraph) " ";
    counter-increment: subparagraph;
}

これで、あなたの論文をLaTeXとHTMLの両方にエクスポートできます。


組織モードでは、すべてのセクションに番号を付けることも、なしにすることもできます。」ええと、プロパティUNNUMBERED: tを見出しに渡すのはどうですか?ORG-NEWSから:プロパティUNNUMBEREDが非ニルである見出しは、レベルに関係なくセクション番号なしでエクスポートされるようになりました。プロパティは子供に継承されます。
rasmus、2015年

@rasmusそれはすごい!ただし、私が知る限り、これはまだリリースされていないorg-mode 8.3でのみ導入されました。
バスティーブ2015年

マスターに実装され、すべてのバックエンドで動作します。Org 8.3が目の前にあります。リリースされていないということは、それをテストし、バグレポートを(必要に応じて)投稿する絶好の機会です。
rasmus、2015年
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.