当前位置: 首页 > wzjs >正文

如何做企业网站推广产品广州网站设计建站

如何做企业网站推广产品,广州网站设计建站,提高工作效率的措施,法律网站模板在这篇博客中,我将详细分析和讲解一段用Python开发的Markdown编辑工具代码。这款工具支持Markdown内容的编辑、HTML预览、导出为PDF和保存为图片的功能,同时还可以实现代码高亮。 C:\pythoncode\new\MarkdownToPdfJpegPreview.py 功能介绍 这款Markdown…

在这篇博客中,我将详细分析和讲解一段用Python开发的Markdown编辑工具代码。这款工具支持Markdown内容的编辑、HTML预览、导出为PDF和保存为图片的功能,同时还可以实现代码高亮。
C:\pythoncode\new\MarkdownToPdfJpegPreview.py


功能介绍

这款Markdown编辑工具基于wxPython开发,核心功能包括:

  1. Markdown编辑与HTML实时预览

    • 提供编辑区域(Memo)供用户录入Markdown内容。
    • 使用wx.html2.WebView组件将Markdown内容转为HTML并实时预览。
  2. 代码高亮

    • 使用Highlight.js实现Markdown代码段的语法高亮。
  3. 导出功能

    • 支持将Markdown保存为.md文件。
    • 将HTML预览内容导出为PDF文件。
    • 将HTML内容保存为JPEG格式的图片。

环境准备

所需的依赖库:
  • wxPython:构建图形界面
  • markdown:将Markdown解析为HTML
  • pdfkit:将HTML转换为PDF文件
  • imgkit:将HTML保存为图片
  • Pillow:处理图像

可以通过以下命令安装:

pip install wxPython markdown pdfkit imgkit pillow
安装wkhtmltopdfwkhtmltoimage工具:

pdfkitimgkit需要wkhtmltopdfwkhtmltoimage工具的支持。

  • 下载地址:wkhtmltopdf
  • 安装后,将工具路径(如C:\Program Files\wkhtmltopdf\bin)加入环境变量,或在代码中显式指定路径。

代码分析

下面是实现Markdown编辑工具的完整代码:

import wx
import wx.html2  # HTML浏览器控件
import markdown  # Markdown解析模块
import pdfkit    # HTML转PDF模块
from PIL import Image
from io import BytesIO
import imgkitdef markdown_to_html_with_highlight(md_content):"""将Markdown转换为HTML并添加代码高亮支持"""html_content = markdown.markdown(md_content, extensions=['fenced_code'])# 添加Highlight.js脚本和样式highlight_js = '''<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.7.0/styles/default.min.css"><script src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.7.0/highlight.min.js"></script><script>hljs.highlightAll();</script>'''return f"{highlight_js}<body>{html_content}</body>"class MarkdownApp(wx.Frame):def __init__(self):super().__init__(None, title="Markdown编辑工具", size=(1000, 700))self.InitUI()def InitUI(self):# 工具栏toolbar = self.CreateToolBar()toolbar.AddTool(wx.ID_SAVE, "保存 Markdown", wx.ArtProvider.GetBitmap(wx.ART_FILE_SAVE))toolbar.AddTool(wx.ID_PREVIEW, "预览", wx.ArtProvider.GetBitmap(wx.ART_FIND))toolbar.AddTool(wx.ID_PRINT, "生成 PDF", wx.ArtProvider.GetBitmap(wx.ART_PRINT))toolbar.AddTool(wx.ID_SAVEAS, "保存为图片", wx.ArtProvider.GetBitmap(wx.ART_PASTE))toolbar.Realize()# 绑定工具栏按钮事件self.Bind(wx.EVT_TOOL, self.OnSaveMarkdown, id=wx.ID_SAVE)self.Bind(wx.EVT_TOOL, self.OnPreview, id=wx.ID_PREVIEW)self.Bind(wx.EVT_TOOL, self.OnGeneratePDF, id=wx.ID_PRINT)self.Bind(wx.EVT_TOOL, self.OnSaveImage, id=wx.ID_SAVEAS)# 布局panel = wx.Panel(self)vbox = wx.BoxSizer(wx.VERTICAL)self.memo = wx.TextCtrl(panel, style=wx.TE_MULTILINE)self.browser = wx.html2.WebView.New(panel)vbox.Add(self.memo, 1, wx.EXPAND)vbox.Add(self.browser, 1, wx.EXPAND)panel.SetSizer(vbox)self.Show()def OnPreview(self, event):"""预览Markdown内容为HTML"""md_content = self.memo.GetValue()html_content = markdown_to_html_with_highlight(md_content)self.browser.SetPage(html_content, "")def OnSaveMarkdown(self, event):"""保存Markdown为.md文件"""with wx.FileDialog(self, "保存 Markdown", wildcard="Markdown 文件 (*.md)|*.md",style=wx.FD_SAVE | wx.FD_OVERWRITE_PROMPT) as dialog:if dialog.ShowModal() == wx.ID_CANCEL:returnpath = dialog.GetPath()with open(path, 'w', encoding='utf-8') as file:file.write(self.memo.GetValue())def OnGeneratePDF(self, event):"""生成PDF文件"""md_content = self.memo.GetValue()html_content = markdown.markdown(md_content)with wx.FileDialog(self, "保存 PDF 文件", wildcard="PDF 文件 (*.pdf)|*.pdf",style=wx.FD_SAVE | wx.FD_OVERWRITE_PROMPT) as dialog:if dialog.ShowModal() == wx.ID_CANCEL:returnpath = dialog.GetPath()config = pdfkit.configuration(wkhtmltopdf='C:/Program Files/wkhtmltopdf/bin/wkhtmltopdf.exe')pdfkit.from_string(html_content, path, configuration=config)def OnSaveImage(self, event):"""保存HTML内容为JPEG图片"""md_content = self.memo.GetValue()html_content = markdown.markdown(md_content)with wx.FileDialog(self, "保存图片", wildcard="JPEG 文件 (*.jpeg)|*.jpeg",style=wx.FD_SAVE | wx.FD_OVERWRITE_PROMPT) as dialog:if dialog.ShowModal() == wx.ID_CANCEL:returnpath = dialog.GetPath()config = imgkit.config(wkhtmltoimage='C:/Program Files/wkhtmltopdf/bin/wkhtmltoimage.exe')img_data = imgkit.from_string(html_content, False, config=config)image = Image.open(BytesIO(img_data))image.save(path, format="JPEG")if __name__ == "__main__":app = wx.App()MarkdownApp()app.MainLoop()

功能解析

  1. Markdown解析与HTML预览

    • markdown.markdown()方法将Markdown内容转为HTML。
    • 通过Highlight.js实现代码块的语法高亮。
  2. 生成PDF

    • 使用pdfkit模块的from_string()方法将HTML内容保存为PDF。
    • 需要确保wkhtmltopdf工具正确安装并指定路径。
      需要安装wkhtmltopdf应用程序
      https://wkhtmltopdf.org/downloads.html
  3. 保存为图片

    • 使用imgkit模块生成HTML内容的图片。
    • 使用Pillow库将生成的图像数据保存为JPEG格式。
  4. 界面交互

    • 使用wxPython的工具栏和对话框实现文件保存等功能。
    • 提供预览功能让用户直观地查看Markdown效果。

运行结果

在这里插入图片描述

http://www.dtcms.com/wzjs/533327.html

相关文章:

  • 携程旅行网站内容的建设收录好的博客网站吗
  • 网站如何备案怎么在网上卖东西教程
  • 网站信息 订阅如何做河南工程招标网站
  • 设计专业干货推荐网站wordpress 小工具 功能
  • 网站优化的分析汽车网站建设报价
  • 网站压缩自己做音乐网站挣钱吗
  • 建设部网站官网 造价鉴定上海传媒公司有哪些
  • 金坛区建设局网站南宁网页设计培训班
  • 学用mvc4做网站棋牌网站搭建平台
  • 专业全网优化外贸建站seo
  • 厦门有设计网站的吗wordpress插件不加载
  • 甘肃省嘉峪关建设局网站科技网站颜色
  • 2 如何写一份详细的网站开发方案给客户做网站
  • 海口网站建设品牌大全wordpress 建企业网站
  • 网站 改域名网站开发学什么语言最好
  • 西宁市建设网站价格低柳州网站建设哪里有
  • 网页制作模板的淘宝网站代码做电影网站要多少钱
  • 宁波小网站制作推广图书网站建设的主要工作流程
  • python可以做网站吗wordpress 分类信息模板
  • 成都seo服务桂平百度seo
  • 制作网站用c#做前台哪里制作网站好
  • 如何做社团网站教育房地产 网站建设
  • 南京专业网站制作多少钱龙岗网站建设报价
  • 专题类的网站民制作网站哪家便宜
  • 扬州 网站 建设大型搬家门户网站源码
  • 齐齐哈尔铁峰建设局网站wordpress教程cms
  • 公司网站建设费用会计科目云开发小程序源码
  • 嘉兴企业网站推广衡水专业制作网站
  • 个人做商城网站大概多少钱360网站在系统那里
  • 淘客网站怎么做返利济宁网站建设 智雅