markdown导出为html_python html转word

markdown导出为html_python html转word关于前端HTML转换为Markdown,发现了一个非常好用的npm项目:https://sitdown.mdnice.com/zh-hans/首先确保本机已经安装nodejs,并根据下面的文章安装execjs并修改其源码:execjs执行包含中文参数的JavaScripthttps://xxmdmst.blog.csdn.net/article/details/123099139在python所在目录安装sitdown:>npminstallsitdownadded2pac

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

关于前端HTML转换为Markdown,发现了一个非常好用的npm项目:https://sitdown.mdnice.com/zh-hans/

首先确保本机已经安装nodejs,并根据下面的文章安装execjs并修改其源码:

execjs执行包含中文参数的JavaScript
https://xxmdmst.blog.csdn.net/article/details/123099139

python所在目录安装sitdown:

> npm install sitdown

added 2 packages, removed 220 packages, and changed 93 packages in 4s

确保当前目录中已经安装了sitdown(至少存在node_modules目录),我们就可以通过execjs在python中调用了:

import os
import execjs

print(execjs.get().name)
js_code = """var { Sitdown } = require('sitdown'); let sitdown = new Sitdown({ keepFilter: ['style'], codeBlockStyle: 'fenced', bulletListMarker: '-', hr: '---', }); function html2md(data) { return sitdown.HTMLToMD(data) } """

ctx = execjs.compile(js_code)
html = """<div id="write" class=""><blockquote> <p><span>?博客主页:</span><a href="https://blog.csdn.net/as604049322"><span>https://blog.csdn.net/as604049322</span></a></p> <p><span>?欢迎点赞 ? 收藏 ⭐留言 ? 欢迎讨论!</span></p> <p><span>?本文由 </span><strong><span>小小明-代码实体</span></strong><span> 原创,首发于 </span><strong><span>CSDN</span></strong><span>?</span></p> <p><span>?未来很长,值得我们全力奔赴更美好的生活✨</span></p> </blockquote></div>"""

md = ctx.call("html2md", html)
print(md)

结果:

Node.js (V8)
> ?博客主页:[https://blog.csdn.net/as604049322](https://blog.csdn.net/as604049322)
> 
> ?欢迎点赞 ? 收藏 ⭐留言 ? 欢迎讨论!
> 
> ?本文由 **小小明-代码实体** 原创,首发于 **CSDN**?
> 
> ?未来很长,值得我们全力奔赴更美好的生活✨

可以看到转换效果还不错。

不过这种执行方法耗时较长,每次调用都需要1秒左右的时间。

如果我们需要频繁进行转换,推荐是使用node启动相关的http服务,python直接通过requests获取结果。

在安装目录下新建html2md.js文件,代码如下:

var { 
    Sitdown } = require('sitdown');
var http = require('http');

let sitdown = new Sitdown({ 
   
      keepFilter: ['style'],
      codeBlockStyle: 'fenced',
      bulletListMarker: '-',
      hr: '---',
});

// 创建http server,并传入回调函数:
var server = http.createServer(function (request, response) { 
   
    console.log(request.method + ': ' + request.url);
    let data = '';
    request.on('data', chunk => { 
   
        data += chunk;  // 将接收到的数据暂时保存起来
    });
    request.on('end', () => { 
   
		var markdown = sitdown.HTMLToMD(data);
		response.writeHead(200, { 
   'Content-Type': 'text/html'});
		// 将HTTP响应的HTML内容写入response:
		response.end(markdown);
    });
});

// 让服务器监听18080端口:
server.listen(18080);
console.log('Server is running at http://127.0.0.1:18080/');

执行下面的命令启动nodejs服务:

>node html2md.js
Server is running at http://127.0.0.1:18080/

此时我们在直接http调用:

import requests


def html2md(html, html2md_server="http://127.0.0.1:18080/"):
    res = requests.post(html2md_server, data=html.encode("u8"))
    res.encoding = "u8"
    md = res.text
    return md

html = """<div id="write" class=""><blockquote> <p><span>?博客主页:</span><a href="https://blog.csdn.net/as604049322"><span>https://blog.csdn.net/as604049322</span></a></p> <p><span>?欢迎点赞 ? 收藏 ⭐留言 ? 欢迎讨论!</span></p> <p><span>?本文由 </span><strong><span>小小明-代码实体</span></strong><span> 原创,首发于 </span><strong><span>CSDN</span></strong><span>?</span></p> <p><span>?未来很长,值得我们全力奔赴更美好的生活✨</span></p> </blockquote></div>"""
md = html2md(html)
print(md)

结果与上面一样,但耗时仅15毫秒。

image-20220224161236810

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/196146.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • DotNetTextBox控件添加外挂插件功能的图文教程。

    DotNetTextBox控件添加外挂插件功能的图文教程。在使用DotNetTextBox在线编辑器的时候,你可能觉得控件内置的功能不能满足你的编辑需要,这时DotNetTextBox控件强大的外挂插件功能就发挥作用了,使用外挂插件功能,你就能自行DIY任何自己想实现的功能,而且使用也非常简单,下面我们就为大家演示了为DotNetTextBox增加一个插入网页按钮(button)外挂插件的步骤:第一步:首先用VS2005打开system_dn…

    2022年10月19日
    1
  • 什么是静态代理和动态代理,两者的区别(笔记)「建议收藏」

    什么是静态代理和动态代理,两者的区别(笔记)「建议收藏」文章目录1.什么是代理?2.静态代理3.动态代理4.总结:1.什么是代理?​ 代理:就是让代理角色帮助真实角色完成一件事情;​ 举例:过年回家让朋友代买火车票,朋友帮你买火车票的过程就是代理2.静态代理​ 什么是静态代理:静态代理相当于是多写了一个代理类,在调用的时候调用的是代理类,在代理类中的处理还是原生的处理逻辑,不过在前后添加上需要添加的代码。缺点:需要为每一个被代理的对象都创建一个代理类。​ 特点:​ 代理角色和真实角色都需要实现同一个接口,​ 真实角色专注于自己的.

    2022年10月19日
    3
  • jQuery 教程

    jQuery 教程菜鸟教程—jQuery教程:https://www.runoob.com/jquery/jquery-tutorial.htmljQuery是一个JavaScript库。jQuery极大地简化了JavaScript编程。jQuery简介什么是jQuery?jQuery是一个JavaScript函数库。jQuery是一个轻量级的”写的少,做的多”的JavaScript库。jQuery库包含以下功能:HTML…

    2022年5月29日
    35
  • idea2021激活码【2021免费激活】「建议收藏」

    (idea2021激活码)本文适用于JetBrains家族所有ide,包括IntelliJidea,phpstorm,webstorm,pycharm,datagrip等。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html…

    2022年3月22日
    495
  • muduo网络库使用心得

    muduo网络库使用心得

    2021年12月9日
    56
  • 一生要看的50部经典电影

    一生要看的50部经典电影

    2021年5月4日
    163

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号