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

做原型交互的网站工具网站seo快速排名

做原型交互的网站工具,网站seo快速排名,兼职网站的建设目标怎么写,网站制作 番禺在这篇博客中,我将详细分析和讲解一段用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/251645.html

相关文章:

  • 旅游网站的建设与应用数据分析报告
  • 怎么给网站做百度优化福州百度推广排名
  • 天津建设工程信息网询宁波seo网络推广多少钱
  • 网站规划与建设的流程与方法 高中信息技术360站长工具
  • 网站广告文案千锋教育培训多少钱费用
  • wordpress中文注册插件专业seo站长工具全面查询网站
  • centos网站开发制作网站要花多少钱
  • 坪山商城网站建设哪家公司靠谱百度app下载安装普通下载
  • 精选微信网站建设seo网络排名优化哪家好
  • 网站首页的布局青岛百度关键词优化
  • 珠海网站设计公司b站引流推广
  • 有没有免费做网站的站长工具网站推广
  • 有做赌博网站的么今天重要新闻
  • 布吉网站建设哪家便宜网店代运营
  • 家具网站模版企业营销策略分析论文
  • 网站建设报价新鸿儒如何使用免费b站推广网站
  • 成都网站建设yingrihe比较火的推广软件
  • 网页与网站的区别搜索大全浏览器
  • 宜昌视频网站建设近三天的国内外大事
  • 阿里云怎么建设网站模板网站哪个好
  • 中山网络公司网站百度广告点击一次多少钱
  • 江西安福县建设局网站百度搜索热度查询
  • 网站后期长沙seo网站排名
  • 漯河装修公司网站建设免费发广告的网站
  • 大网站的建设重点长沙网络营销顾问
  • 网站雪花代码互联网的推广
  • 淘宝客做网站需要那些条件seo网站推广经理招聘
  • 网站域名查主机关键词排名优化工具
  • 教育机构网站制作模板今日时政新闻
  • 家用电器销售的网站开发seo优化方案总结