A program for find and upload images in markdown file and will replace them.
Project description
Markdown-img User's Guide
English | 简体中文
Contents
- Project Address
- Usage
- Notes for details
- Supported image bed services
- Install
- Update
- Function
- View the help file
- View the version and configuration information
- Select working language
- Generate a markdown copy of the image bed
- Restore local gallery from the image bed
- Switching the image bed service
- Update the image bed acess token
- Scan images and create indexes
- Refreshing a copy of the image bed
- Backing up the system configuration
- List saved configurations
- Replacing configurations
- Relative path image
- Acknowledgements
- Update Log
Project Address
- pypi:https://pypi.org/project/markdown-img-icexmoon/
- github:https://github.com/icexmoon/markdown-img
- Personal Blog:https://blog.icexmoon.xyz/?p=99
Usage
This program is used to scan the markdown files in the working directory, find the local images in them and upload them to the sm.ms
image bed automatically, and generate a copy of the markdown using the network images to replace the local images, which is stored in the current_working_directory/markdown_image
directory.
By the above way, we can realize the automatic batch markdown image processing work to facilitate the later dissemination of markdown contents on the web.
Notes for details
-
This program will not change the original markdown file, please feel free to use it.
-
This program relies on
sm.ms
image bed, please register your account and generate token by yourself.Support for other image beds has been added, see features for details, but the default is still using sm.ms image bed.
-
Because the
sm.ms
image bed interface has a call limit, if there is a picture upload error, it may be caused by frequent uploads, please wait for more than 1 minute and reuse this program. -
Tencent Cloud Object Storage has been added as a image bed, when using it, you need to enter the corresponding mandatory parameters for connection, you can read the Tencent Cloud OSS User Guide for specific parameters, in addition, you need to set the object storage service to private write public read.
-
Currently this program only supports windows.
Theoretically supports all platforms that can run Python, but has not been tested on other platforms at this time.
-
sm.ms
access is not considered friendly in China, generated markdown copy immediately published on the network may show anti-theft chain and other images hanging, that is because the domestic CDN is relatively slow, wait for a period of time on the good. -
This program is written in Python, you need to install the Python runtime environment, if you don't know how to install, you can read the python environment installation under windows.
Supported image bed services
Image bed name | Flag | Bed nature | Access token required | Notes |
---|---|---|---|---|
sm.ms | smms | Public | Yes | Default image bed, foreign old public image bed service provider, trustworthy, the disadvantage of domestic access is unstable. |
yujian | yujian | Public | Yes | A domestic image bed service, in addition to providing its own image bed service, also supports calling other image bed services through its API. |
ruyou | rruu | Public | Yes | As you can see and met with the same set of website code, the site is currently closed, the service is not available. |
ali | ali | Public | Yes | Unusual service, supported by the API implementation of yujian image bed, used with caution. |
Vim-CN | vimcn | Public | No | A foreign bed service provider, said to be the same old service provider, the same disadvantage of domestic access is unstable. |
Tencent Cloud COS | qcloud | Private | Yes | There is nothing to say, several private cloud storage in the most recommended, the disadvantage is that currently only provides a year of free credit, the expiration of the need to renew. |
Qiniu Cloud | qiniu | Private | Yes | Provide permanent free storage quota, the disadvantage is not to provide a domain name for the stored external links, you need to own a domain name and binding operation before you can use it. |
bilibili | bilibili | Public | Yes | Unusual service, supported by the API implementation of yujian image bed, used with caution. |
Sougou | sougou | Public | Yes | Unusual service, supported by the API implementation of yujian image bed, used with caution. |
Huluxia | huluxia | Public | Yes | Unusual service, supported by the API implementation of yujian image bed, used with caution. |
Catbox | catbox | Public | Yes | Unusual service, supported by the API implementation of yujian image bed, used with caution. |
360 | 360 | Public | Yes | Unusual service, supported by the API implementation of yujian image bed, used with caution. |
Tietu | postimages | Public | Yes | Unusual service, supported by the API implementation of yujian image bed, used with caution. |
58 | ai58 | Public | Yes | Unusual service, supported by the API implementation of yujian image bed, used with caution. |
Jitu | gtimg | Public | Yes | Unusual service, supported by the API implementation of yujian image bed, used with caution. |
Baitu | bkimg | Public | Yes | Unusual service, supported by the API implementation of yujian image bed, used with caution. |
Muke | muke | Public | Yes | Unusual service, supported by the API implementation of yujian image bed, used with caution. |
Upay Cloud | upyun | Private | Yes | Provide vouchers, the disadvantage is not to provide a domain name for the stored external links, you need to own a domain name and binding operation before you can use it. In addition, white whoring vouchers need to join the Alliance, and once a year audit. |
Install
pip install markdown-img-icexmoon
Update
pip install --upgrade markdown-img-icexmoon
Function
Added console short command support, all functions can be called quickly via
pymdimg
.For example,
pymdimg -h
is exactly the same aspython -m markdown_img -h
.
View the help file
- Execute
python -m markdown_img -h
。
View version and configuration information
Excute pymdimg -v
or pymdimg --version
.
Select working language
English and Chinese are supported as working languages, the default is Chinese.
- Execute
pymdimg -l en
to switch the working language.
Image Compression
Enabling this feature will compress images over a certain size and then upload them to the image bed to save private storage space. The compressed intermediate images will be automatically deleted from the local area and will not affect the original local images.
- Execute
pymdimg --compress
to set the relevant configuration and then turn it on.
Switching image compression engines
GIL and tinyPNG are currently supported, the former for local compression using a third-party Gillow package, and the latter for online compression using the online service tinyPNG.com, the latter is recommended because the latter is lossless compression, but the latter requires registration to generate an access token first, and free users have the number of calls: 500 per month.
Execute pymdimg -e tinyPNG
to switch.
Generate a markdown copy of the image bed
The main function of this program, will scan the markdown file in the command line working directory, will replace the local image in it with a bed image and then generate a copy of the bed, the generated copy will be stored in the markdown_img
folder in the working directory.
- Use CMD to locate the directory where the markdown file will be processed.
- Execute
python -m markdown_img
. - The first time you run the program you will be prompted to enter the markdown token.
- Enter it and execute step 2 again.
- Wait for processing.
- When you are done, check the
working_directory/markdown_img
directory.
- The token is stored in the
main.config
file in the directory where the program is located. You can modify it yourself if you need to, or you can delete the configuration file and run the program again to enter it.- The command parameters of the program will be enriched and refined later.
- If the URL returned by the target image bed contains special characters such as Chinese or spaces, and your markdown text editor cannot preview the corresponding image properly, you may need to use URL ENCODE to process it, turn on this function by
pymdimg -u standard
, and regenerate the copy after turning on. This feature currently only works with Tencent OSS, because other image beds will not return Chinese URLs.- A copy can be generated using a specified configuration, such as
pymdimg --config normal
, which allows you to use a customized related configuration to complete this task without modifying the current configuration in specific scenarios, such as when you want compression not to apply in this task, or when you use large scale compression. See [Function: Backup system configuration] for the specific function of making related configurations.
Restore local gallery from the image bed
If the copy of the image bed is intact, but the local images associated with the native markdown file are missing, you can use this function to try to recover them.
- Switch the command line working directory to the directory of the markdown file you want to restore.
- Excute
python -m markdown_img -m img_recove
- Wait for processing.
- Check if the local markdown file image is restored after it is finished.
- Because the network image bed is unstable, although the program itself has a timeout reconnection mechanism, if too many images are recovered, it is likely that the processing will be interrupted and the program will simply need to be rerun.
- The recovery logic is to compare the order of appearance of the images in the copy and the original, and recover them 1 to 1. So it is important to ensure that there is no difference between the two, and the program will interrupt when the number of both is different and prompt the user to confirm manually.
Switching the image bed service
You can switch the image bed service in case a certain image bed is not available or the access is unstable.
Currently supported image beds are sm.ms, Ali, RuYu, Vim-CN, meet, Tencent cloud object storage (promotional link),Qiniu Cloud.
For a list of supported image beds, see Supported Image Bed Services.
- Excute
python -m markdown_img -i ali
- You can check the help documentation for the specific image bed logo.
- Access tokens are required to switch the bed service and will be prompted to enter the appropriate access token in use.
- Some necessary information is required to use Tencent Cloud OSS, please read the notes for details.
- You need to provide the necessary information when using Qiniu Cloud Storage, where the DNS binding domain name needs to include the protocol, such as
http://example.domain.com
Update the image bed access token
If a wrong access token is set for the image bed token, or if a new access token is regenerated on the image bed website, you can update the corresponding access token in the program.
- Excute
python -m markdown_img -c smms
You can check the help documentation for specific parameters.
Part of the image bed configuration if more than one, you can use subcommands to modify only a single configuration, for example, only modify the Tencent cloud storage directory:
pymdimg -c qcloud --des_dir image
, if there are spaces in the middle of the target directory, you need to give will be wrapped in English double quotes, such as this:pymdimg -c qcloud --des_dir "我 love 你"
. After updating the configuration you can usepymdimg -v
to confirm that the configuration has been set correctly.
Scan images and create indexes
If you need to upload all the images in a directory to a webbed and create a markdown file as an index file, then this is the right function to use.
python -m markdown_img -s
- The index file will be regenerated each time it is run.
- The name of the generated index file is
markdown_img_index.md
, please make sure not to customize the file with the same name in the target directory.- You can use the specified configuration, such as
pymdimg -s --config normal
, as described in the relevant entry in [Generating a copy of the mapbed markdown].
Refreshing a copy of the image bed
If your original md file has been updated and you don't want to delete the corresponding copy file manually and want to regenerate it automatically, you can use this function.
python -m markdown_img -m refresh
Scans the current directory for the original md file, and if there is no copy, creates it directly. If there is a copy, but the original file is "newer" than the copy, the copy is recreated.
Backing up the system configuration
If necessary, the system configuration can be backed up by
pymdimg -m backup_config --name xxx
The --name
parameter is not required, if not specified a configuration backup file name will be generated based on the current time.
List saved configurations
pymdimg --list_config
will list the configuration name and creation time
Replacing configurations
You can replace the current configuration with a saved configuration:
pymdimg --change_config xxx
where xxx
is the file name of the saved configuration you want to replace. To see what saved configurations are available, please use [Function: List saved configurations]. In addition, it is better to save the current configuration before using this function.
Relative path image
You can process the MD file using absolute path pictures to use relative path pictures, and the program will copy the original pictures to the images subdirectory of the current directory as relative path pictures.
The purpose of this function is to provide convenience for some cross-platform, multi-device users, using relative paths, raw images and MD files can be easily moved, or using a synchronization service similar to Nut Cloud for multi-device synchronization.
pymdimg -m relative_img
- In order to avoid the corruption of the original MD file caused by program errors, one original file will be kept and backed up in the backup subdirectory.
- Because of the difference between Windows and Linux platform separators, there is no guarantee that the relative directories of both will behave properly.
Acknowledgements
The developer of this application has received help and support from upyun for its free CDN acceleration and cloud storage services, if you want to get the same help and support, you can Click here to join.
Update Log
0.2.8
Add globalization support. add English as a new working language.
0.2.9
Add Qiniu Cloud as a new optional image bed.
0.3.0
- Code refactoring
- Add bilibili as new image bed
- Fix some bugs
0.3.1
Add UPYun Cloud as a new optional image bed.
0.3.2
Add image compression feature.
0.3.3
Add TinyPNG as a new image compression engine.
0.3.4
Compression engine switch option add none, can be more convenient to turn off the compression function.
0.3.5
Add system configuration backup function.
0.3.6
Add the function of using specified configuration.
0.3.7
Fix the bug that can't install successful caused by use futures module.
0.3.8
Fix the bug that can't create img dir normally in Linux.
0.3.9
Added the function to modify the absolute path image in the MD file to relative path.
0.4.0
Added the support to fengzhen image bed.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file markdown-img-icexmoon-0.4.0.tar.gz
.
File metadata
- Download URL: markdown-img-icexmoon-0.4.0.tar.gz
- Upload date:
- Size: 40.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.10.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 267f42a58438d8d9573f0225a8628dc46b3968fa843ddf732cf9695a58dc8a5d |
|
MD5 | ea95ca83059894268538d67b2cee392d |
|
BLAKE2b-256 | 966a21c8900f15fa47436c65da32866908482bd84ec29a53ef9cdc0ea513d75a |
File details
Details for the file markdown_img_icexmoon-0.4.0-py3-none-any.whl
.
File metadata
- Download URL: markdown_img_icexmoon-0.4.0-py3-none-any.whl
- Upload date:
- Size: 48.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.10.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 85106515de02d804966325ebbae8efbcdb09d7c2a80f0d2241288beb0db922b2 |
|
MD5 | 19b17ce90fba6bcae0f440031b08755c |
|
BLAKE2b-256 | 55a952a36c2847103c9685accd20979db129915649ecdb167d673e87545a955a |