python 自動化將markdown文件轉(zhuǎn)成html文件的方法
一、背景
我們項(xiàng)目開發(fā)人員寫的文檔都是markdown文件。對于其它組的同學(xué)要進(jìn)行閱讀不是很方便。每次編輯完markdown文件,我都是用軟件將md文件轉(zhuǎn)成html文件。剛開始轉(zhuǎn)的時(shí)候,還沒啥,轉(zhuǎn)得次數(shù)多了,就覺得不能繼續(xù)這樣下去了。作為一名開發(fā)人員,還是讓機(jī)器去做這些瑣碎的事情吧。故寫了兩個腳本將md文件轉(zhuǎn)成html文件,并將其放置在web服務(wù)器下,方便其他人員閱讀。
主要有兩個腳本和一個定時(shí)任務(wù):
•一個python腳本,主要將md文件轉(zhuǎn)成html文件;
•一個shell腳本,主要用于管理邏輯;
•一個linux定時(shí)任務(wù),主要是定時(shí)執(zhí)行shell腳本。
二、用python將markdown轉(zhuǎn)成html
2.1 python依賴庫
使用python的markdown庫來轉(zhuǎn)換md文件到html依賴兩個庫:
•pip install markdown
•pip install importlib
2.2 核心代碼
核心代碼其實(shí)只有一句,執(zhí)行 markdown.markdown(text)就可以獲得生成的html的原文。
input_file = codecs.open(in_file, mode="r", encoding="utf-8") text = input_file.read() html = markdown.markdown(text)
2.3 html編碼和html樣式
直接markdown.markdown(text)生成的html文本,非常粗略,只是單純的html內(nèi)容。而且在瀏覽器內(nèi)查看的時(shí)候中文亂碼(在chrome中),沒有好看的css樣式,太丑了。
解決辦法也很簡單,在保存文件的時(shí)候,將<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />和css樣式添加上。就這么簡單解決了。
2.4 完整python內(nèi)容
•讀取md文件;
•將md文件轉(zhuǎn)成html文本;
•添加css樣式和保存html文本。
python代碼內(nèi)容:
#!/usr/bin/env python # -*- coding: utf-8 -*- # 使用方法 python markdown_convert.py filename import sys import markdown import codecs css = ''' <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <style type="text/css"> <!-- 此處省略掉markdown的css樣式,因?yàn)樘L了 --> </style> ''' def main(argv): name = argv[0] in_file = '%s.md' % (name) out_file = '%s.html' % (name) input_file = codecs.open(in_file, mode="r", encoding="utf-8") text = input_file.read() html = markdown.markdown(text) output_file = codecs.open(out_file, "w",encoding="utf-8",errors="xmlcharrefreplace") output_file.write(css+html) if __name__ == "__main__": main(sys.argv[1:])
三、shell邏輯
3.1 邏輯說明
建立一個shell文件,用于進(jìn)行邏輯處理,主要操作如下:
•更新svn文件,將最新的md文件更新下來(此處假設(shè)md文件是測試文檔.md);
•執(zhí)行python markdown_convert.py $NAME將md文件轉(zhuǎn)成html文件(生成測試文檔.html);
•將轉(zhuǎn)好的html遷移到web路徑下(移動到html/測試文檔.html);
•啟動一個web服務(wù)(此處用的是python的SimpleHTTPServer的web服務(wù)器).
3.2 完整shell邏輯
#!/bin/bash
NAME='測試文檔'
## 更新代碼
svn update
## 刪除html文件
if [ -f "$NAME.html" ];then
rm "$NAME.html"
fi
## 生成html
if [ -f "$NAME.md" ];then
python markdown_convert.py $NAME
fi
## 生成html目錄
if [ ! -d "html" ];then
mkdir "html"
fi
## 拷貝html文件
if [ -f "$NAME.html" ];then
mv -f "$NAME.html" "html/"
fi
## 開啟web服務(wù)器
PID=`ps aux | grep 'python -m SimpleHTTPServer 8080' | grep -v 'grep' | awk '{print $2}'`
if [ "$PID" = "" ];then
cd html
nohup python -m SimpleHTTPServer 8080 &
echo 'start web server'
else
echo 'already start'
fi
四、linux定時(shí)任務(wù)
在shell命令下輸入crontab -e進(jìn)入linux定時(shí)任務(wù)編輯界面。在里面設(shè)置markdown2web.sh腳本的定時(shí)任務(wù):
## 更新文檔 */10 * * * * cd /home/xxx/doc; sh markdown2web.sh > /dev/null 2>&1
以上所述是小編給大家介紹的python 自動化將markdown文件轉(zhuǎn)成html文件的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Python + selenium + crontab實(shí)現(xiàn)每日定時(shí)自動打卡功能
這篇文章主要介紹了Python + selenium + crontab實(shí)現(xiàn)每日定時(shí)自動打卡功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-03-03
Python實(shí)現(xiàn)利用163郵箱遠(yuǎn)程關(guān)電腦腳本
這篇文章主要為大家詳細(xì)介紹了Python實(shí)現(xiàn)利用163郵箱遠(yuǎn)程關(guān)電腦腳本,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-02-02
Python辦公自動化Word轉(zhuǎn)Excel文件批量處理
這篇文章主要為大家介紹了Python辦公自動化Word轉(zhuǎn)Excel文件批量處理示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06
快速解決pyqt5窗體關(guān)閉后子線程不同時(shí)退出的問題
今天小編就為大家分享一篇快速解決pyqt5窗體關(guān)閉后子線程不同時(shí)退出的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-06-06
Python使用matplotlib繪制三維參數(shù)曲線操作示例
這篇文章主要介紹了Python使用matplotlib繪制三維參數(shù)曲線操作,結(jié)合實(shí)例形式分析了Python使用matplotlib的數(shù)值計(jì)算與圖形繪制相關(guān)操作技巧,需要的朋友可以參考下2019-09-09

