MarkupViewer is a simple previewer for various markup formats. The view will be refreshed when the opened file is saved, allowing you to use whatever editor you’d like and see the results immediately.
- Cross Platform (tested only on Windows though)
- Updates when the file is changed
- Auto scroll to changed part
- Stylesheet support
- View various markup formats (asterisk determines formats require Pandoc to be installed):
- AsciiDoc
- Creole
- DocBook*
- EPUB*
- Markdown, Pandoc-flavour*, GitHub-flavour*, PHP Markdown Extra*
- MediaWiki*
- reStructuredText
- LaTeX*
- Office Open XML* (aka docx)
- OPML*
- OrgMode*
- Textile
- txt2tags*
- Linked table of content as a menu or in sidebar (you can filter headers to find one)
- Statistics — words, characters and lines count
It, also, tries to count amount of the unique words in a document. However, take the results with a grain of salt — the application has no clue about grammatical cases. - Drag and drop any file on an existing MV window to preview the file
- Python 2.7
- PyQt4
- Optional dependencies (any single one of them will be enough for correct support of appropriate format(s); asterisk determines packages are required for support of all declared formats):
- PyYAML is needed to read settings, if not installed MV will work using default settings
- asciidoc* (see
.\asciidoc\README.asciidoc
for details) - python-creole*
- pandoc*
- docutils
- Markdown
- textile
$ python MarkupViewer.py <file>
To automatically open a file with this viewer in Windows, associate the filetype with the included .bat
file.
You can apply styles by dropping your stylesheets in the stylesheets\
directory next to this script and selecting one from the Style menu.
To automatically open a file with this viewer in Ubuntu, create MarkupViewer.desktop
file with following content:
[Desktop Entry]
Name=MarkupViewer
Comment=A simple previewer for various markup formats
Exec=/full/path/to/MarkupViewer/MarkupViewer.sh %f
Terminal=false
Type=Application
Replace /full/path/to
with actual full path; move this file to ~/.local/share/applications
and open mimeapps.list
in this directory (or create if mimeapps.list
does not exist), add association, e.g. for Markdown:
[Default Applications]
text/x-markdown=MarkupViewer.desktop
Make desktop
and sh
files executable in their properties in file explorer, or with chmod command in terminal.
MarkupViewer does support Unicode [and only Unicode] as much as Python2 and PyQt4 allow:
Since some of 3rd party software, used for conversion, support only UTF8 encoding (Pandoc, Markdown Python library, etc.) MarkupViewer assumes that file encoding is UTF8, although some software support other encodings (e.g. AsciiDoc, docutils)—MV ignores it.
Feel free to make improvements. Fork and send me a pull request.
Building standalone app using PyInstaller
$ pyinstaller build.spec
Though, docutils and textile packages need to be copied by hand into root of resulted folder dist\MarkupViewer
..\Python27\Lib\site-packages\docutils-0.11-py2.7.egg\docutils
..\Python27\Lib\site-packages\textile-2.1.5-py2.7.egg\textile
The bundled style came from here.
© 2013 Matthew Borgerson [email protected]
© 2014 Vova Kolobok [email protected]
This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
markup.ico is based on the markdown mark and dedicated to the public domain.
Font Awesome under SIL
© 2012 Dave Gandy http://fortawesome.github.com/Font-Awesome
Entypo under CC BY-SA
© 2012 Daniel Bruce http://www.entypo.com