'Hard Code Markdown Images
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
Solution 1:[1]
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]()
Solution 2:[2]
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)
Sources
This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.
Source: Stack Overflow
Solution | Source |
---|---|
Solution 1 | Wamadahama |
Solution 2 | Xiao |