Skip to content

Latest commit

 

History

History
110 lines (77 loc) · 6.67 KB

README.md

File metadata and controls

110 lines (77 loc) · 6.67 KB

md2docx

markdown -> docx word

Why is MS Word not always the right choice?

Microsoft Word is one of the most well-known de facto standards for documentation in many companies. It is a powerful tool with many features and settings. And everything looks perfect if you don’t need to make a lot of changes by many employees and keep track of all these changes, discussions and approvals. But we have another powerful tool with an excellent reputation for managing all of this. This is GIT. It is used in the development, but why not to use it for documentation?

Idea

If we want to take full advantage of GIT we have to use something else instead of Word. I think MarkDown is a good choice. It is powerful enough and allows us to use GIT (for example, GitHub) to manage all changes.

Now, if we have all the documentation created in MarkDown, we can think about their automatic conversion to Word with all necessary corporate styles and requirements.

Possible or not?

We have Pandoc to convert MarkDown to Word. But, of course, we can not convert everything, and we have a lot of things in Word which are missing in MarkDown. So I think it is impossible or very difficult to solve this task in general for all cases.

But the fact is that we don’t need to solve this problem for all cases. We only need to solve this for our particular one.

For example, in my case I only need to

  • add styles for all tables (in accordance with corporate requirements)
  • insert automatic table captions
  • insert automatic image captions

and I have exactly the same Word file that I had when I created it manually (old style).

For this change we may use VBA macros but I prefer to use pywin32 package for python.

Instruments

  • Markdown with some editor (I use Typora) - documents creation
  • GIT (GitHub for example) - version control system
  • Pandoc - MarkDown->Wod (docx) conversion
  • YAML - YAML file (structure.yml) describes the structure of the final Word document and contains other input parameters for python script (render.py)
  • Python with pywin32 - pywin32 is used for Word file change
  • MS Word (docx) - resulting document

Procedure

  • if the document is large (for example, LLD), divide it into smaller pieces. Manage several small documents instead of one large.
  • use MarkDown with one of the markdown editors (I use Typora)
  • use GIT (gitlab, GithHub)
  • generate Microsoft Word document with all necessary styles, fields, templates,.. when it is needed. It should be one click procedure.

High Level Workflow

  • Only MarkDown files are modified manually. Instead of managing one large file, it’s easier to manage several smaller ones
  • One of the first operations performed by render.py is to convert the MarkDown files to docx format. This Word files have no styles, fields.. They are temporary and render.py removes them in the end
  • Using the structure.yml data and temporary docx files (created earlier) as input, render.py adds all the necessary Word objects (for example, fields), implement the styles and paste the converted data into the correct places in the resulting Word document

render.py workflow:

render.py

From structure.yml you can see how this script works.

actions:
   structure_verification: "yes"
   change_data: "yes"
   table_style: "yes"
   table_caption: "yes"
   figure_caption: "yes"
   update_fields: "yes"

  • structure_verification - verifies if the section corresponds the title
  • change_data - inserts data in this section
  • table_style - changes the table style
  • table_caption - transforms markdown caption to the word caption for tables
  • figure_caption - transforms markdown caption to the word caption for figures
  • update_fields - updates all fields

Installation

Was tested for Windows 10.

  • clone this project into your local folder
  • install Python3 with YAML and pywin32 packages (win32com.client)
  • install Pandoc
  • install any MarkDown editor. I use Typora. Any simple text editor can be used, but this is not very convenient
  • copy folder 'example' to your local git repository. Change the name of the folder in accordance with your project. Now you can use this folder for new documentation creation
  • edit mkword.py file: change the path to the script/render.py file if necessary
  • edit or create appropriate Word template file
  • change or create structure.yml file
  • create MarkDown file
  • execute python3 mkword.py
  • new Word file will be created from your MarkDown file
  • now you can use git for documentation creation

Files in Example

  • render.py - Python script. Takes data from the markdown file, converts and inserts it into a Word document. This is a static file. You usually don't need to change it. You even don't need to copy this file to your local git repository but you need to add the path to this file into mkword.py file
  • structure.yml - YAML file with all the necessary parameters for render.py. Normally you adjust this file only once at the beginning. The path is used as argument for the mkword.py.
  • folder templates - folder with Word templates
  • template.docx is a Word document that we are going to fill out with the context of markdown documents. This Word document should have all the styles, templates ... you are going to use. This document is divided manually into sections. Each section corresponds to one chapter
  • folder media - folder with pictures
  • example_chapter.md - markdown document with example information. Of course, for your documentation, the name will differ. You have to add the path to this file into mkword.py file
  • mkword.py - python script. You have to edit this file and change the path to render.py file. Syntax is: python3 mkword.py structure/structure.yml

How to start

To see how it works you can start with example.

  • cd example
  • python3 mkword.py structure/structure.yml
  • yes Check your templates/template.docx file. It should be opened and have a new content from example_chapter.md file. Close this file without saving.