56tvmao: How-to instructions you can trust. productivity How to Add Colored Terminal Code to Microsoft Word

How to Add Colored Terminal Code to Microsoft Word

If you want to put Terminal code in Word with the correct colorization, just copy and paste won’t work. You’ll need to use a tool to generate colorized HTML, then import the HTML into Word. We can use ansi2HTML to convert our Terminal code to HTML, then drop it into our Microsoft Word document.

Using ansi2HTML to create colored Terminal code as HTML

If you’re on macOS or Linux or have a Linux shell running on Windows, you can use ansi2HTML to output colored Terminal code into Microsoft Word.

Also read: How to Properly Style Text in Microsoft Word

Install ansi2HTML

Without access to yum, we need a package manager to allow us to install ansi2HTML.

Unfortunately, the package is not on Homebrew, but we can get it from pip. If you don’t already have pip installed, grab it by running the command below in Terminal:

sudo easy_install pip

Once you have pip installed, you can pull ansi2HTML down from pip with this command:

pip install ansi2html

Linux users with yum available can use the following commands to install:

sudo yum install python-ansi2html

Using ansi2HTML in Terminal

With ansi2HTML installed, we can now use it in Terminal.

The general syntax for ansi2html is:

ls --color=always | ansi2html > directories.html

First comes the command we want to print out with any colorization flags enabled. Then we pipe that output to ansi2html and use a caret to export it to a file with the .html extension.

For example, to print my macOS system logs in color, I might run something like the following:

sudo tail /var/log/system.log | ccze -A | ansi2html > logs.html

Eagle-eyed readers will note that I’ve interspersed ccze as a secondary step to colorize my logs. You can grab that from Homebrew with brew install ccze.

Open the resulting HTML file, and we will see the colorized output of our command.

Note that you need to be careful to explicitly colorize the code coming out of Terminal, as the pipe command ( | ) often strips colorization even if your environmental variables request otherwise.

Pasting Colored HTML into Word

Now that I’ve generated colored HTML, I need a way to put that into Word.

1. From the “Insert” menu on the ribbon in Microsoft Word, select “Text from File” under the Object icon’s dropdown.

If you don’t see that icon, make sure you’ve maximized your Word window to reveal all the icons in the ribbon.

2. In the pop-up file browser, select the HTML file that ansi2HTML created. The colored text will be copied into Word.

Changing ansi2HTML’s color scheme

As you can see, some of the text is a little difficult to read. We can adjust the colors manually in two places. In this instance, the first would be the ccze command, which was responsible for applying the color initially. But more directly, we can edit the CSS in the HTML file that ansi2HTML created.

1. Open the HTML file in a text editor.

2. In the head of the HTML document we can see the auto-generated CSS.

3. ansi2HTML defines a number of classes to apply colors. We simply need to see which classes are associated with the colors we want to change, then pick a more suitable color.

We can also run ansi2HTML in light color mode using the -l flag, like so:

ansi2html -l > logs.html

This produces much more legible output against a white background, though it’s not as attractive:

You could also put shorter code blocks in a textbox and set the background to a dark color, but that’s probably the least flexible option.

Conclusion

A similar process can be used to colorize a variety of code. If you can produce colorized standard output in Terminal, you can “print” that to ansi2HTML and drop it into Word.


Alexander Fox

Alexander Fox is a tech and science writer based in Philadelphia, PA with one cat, three Macs and more USB cables than he could ever use.

Subscribe to our newsletter!

Our latest tutorials delivered straight to your inbox

Sign up for all newsletters.
By signing up, you agree to our Privacy Policy and European users agree to the data transfer policy. We will not share your data and you can unsubscribe at any time. Subscribe

Related Post