Hard Code Markdown Images
Asked Answered
P

3

30

I am just making a general markdown page to share a design guide with everyone on the project. I would like to know how I can hard code the images I use into the .md file. I do not want to have to share a folder full of images each time I want to give someone the .md file.

What would be the best way to hard code/build the markdown project into one single file?

One idea is to convert all the images into base64, but of course that is not a very pretty solution. Another idea is to host the images somewhere but then they would need internet access and the images would possibly be public, so that is not a solution either.

My current code:

![placehoder text](images/the-image.jpg)

Where I have an images folder next to the .md and the "the-image.jpg" inside that folder

Pistoia answered 12/6, 2018 at 12:41 Comment(0)
P
52

You should write the document in markdown and then convert it to PDF using a tool like pandoc

However your base64 solution would work. See this

![Hello World]()
Politics answered 12/6, 2018 at 12:46 Comment(3)
FYI: This doesn't work on GitHub nor GitLab. This does work on VSCode's built-in Markdown preview.Overarm
it does work in vscode at the momentGarboard
Does work for Metabase Text-boxMullis
G
14

this is my first post to stack overflow so please be kind :)

a little piece of python i used to do this one for me... copy and paste the entire output file directly into the markdown document... worked for me...

# function to create embedded image string as base64:

    def image_to_base64(image_file, output_file):

      # need base 64
      import base64,sys
      # open the image
      image = open(image_file, 'rb') 
      # read it
      image_read = image.read() 
      # encode it as base 64
      # after python>=3.9, use `encodebytes` instead of `encodestring`  
      image_64_encode = base64.encodestring(image_read) if sys.version_info <(3,9) else base64.encodebytes(image_read)
      # convert the image base 64 to a string
      image_string = str(image_64_encode)
      # replace the newline characters
      image_string = image_string.replace("\\n", "")
      # replace the initial binary
      image_string = image_string.replace("b'", "")
      # replace the final question mark
      image_string = image_string.replace("'", "")
      # add the image tags
      image_string = '<p><img src="data:image/png;base64,' + image_string + '"></p>'
      # write it out
      image_result = open(output_file, 'w')
      image_result.write(image_string)
Guanine answered 31/10, 2019 at 0:16 Comment(1)
Thanks for your contribution, very helpful!Qktp
Y
0

Knowing this is an old thread, but for future reference sake, this method does not work with Notion when importing Text/Markdown.

Yeasty answered 15/7 at 23:29 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.