Python 自动化实践:Typora 自定义上传接口与兰空图床集成

针对上一篇博客《使用 Python 脚本一键上传图片到兰空图床并自动复制链接》,此篇博客使用自己常用的Typora md编辑器,将 Python 脚本集成到 Typora 的"上传服务"中,可以实现插入图片时自动上传至兰空图床(Lsky Pro)并自动替换链接。

以下是具体操作步骤及针对 Typora 优化的脚本代码。

1. 编写 Typora 专用上传脚本

Typora 的自定义上传功能要求脚本在成功后,向标准输出(Stdout)打印特定的格式:

  1. 第一行打印 Upload Success:
  2. 随后每一行打印一个上传成功的图片 URL。

请将以下代码保存为 typora_upload.py

python 复制代码
import requests
import sys
import os

# --- 核心配置 ---
API_URL = "https://your-domain.com/api/v1/upload"  # 替换为你的 API 地址
TOKEN = "your_auth_token_here"                      # 替换为你的 API Token
# ----------------

def upload_for_typora(file_paths):
    headers = {
        'Authorization': f'Bearer {TOKEN}',
        'Accept': 'application/json',
        'User-Agent': 'Typora-Uploader'
    }

    urls = []
    
    for path in file_paths:
        if not os.path.isfile(path):
            continue
            
        try:
            with open(path, 'rb') as f:
                files = {'file': (os.path.basename(path), f)}
                response = requests.post(API_URL, headers=headers, files=files, timeout=30)
                
                if response.status_code == 200:
                    res_json = response.json()
                    if res_json.get('status'):
                        urls.append(res_json['data']['links']['url'])
        except Exception:
            pass

    # 符合 Typora 输出规范
    if urls:
        print("Upload Success:")
        for url in urls:
            print(url)
    else:
        print("Upload Failed")
        sys.exit(1)

if __name__ == "__main__":
    # Typora 会一次性传入一个或多个图片路径作为参数
    image_paths = sys.argv[1:]
    upload_for_typora(image_paths)

2. 在 Typora 中配置

  1. 打开 Typora,进入 设置 (Preferences)

  2. 导航至 图像 (Image) 选项卡。

  3. 插入图片时 (When Insert):选择"上传图片 (Upload image)"。

  4. 勾选:

    • 对本地位置的图片应用上述规则 (Apply above rules to local images)。
    • 对网络位置的图片应用上述规则 (Apply above rules to online images)。
  5. 上传服务 (Image Uploader) :选择 Custom Command

  6. 命令 (Command):填写运行脚本的命令。

    • Windows 示例python "C:\路径\to\typora_upload.py"
    • macOS/Linux 示例python3 "/Users/路径/to/typora_upload.py"
    • 若为虚拟环境,可填写实际环境的python路径,如/Users/zhyong/Project/local_python_env/.venv/bin/python3 /Users/路径/to/typora_upload.py
  7. 点击 验证图片上传选项 (Test Uploader) 进行测试。

此时,打开图床后,就有测试上传的两张图片了。

3. 技术要点与注意事项

  • Stdout 依赖 :Typora 通过捕获脚本的控制台输出来获取 URL。脚本内不可存在多余的 print 语句,否则会导致 Typora 解析失败。
  • 多图处理 :Typora 有时会同时传输多张图片(例如批量粘贴时),脚本中使用 sys.argv[1:] 获取所有路径参数并循环处理。
  • 依赖库检查 :确保当前系统环境已安装 requests 库。若使用虚拟环境,需在"命令"栏填写该虚拟环境的 python 解释器绝对路径。
  • 权限问题:在 macOS/Linux 系统上,若执行失败,请检查脚本文件是否具有可执行权限,或尝试使用绝对路径引用 Python 解释器。

4. 自动化逻辑说明

  • 触发时机:当图片被拖入、粘贴或通过菜单插入 Typora 时,脚本会自动触发。
  • 链接替换 :上传成功后,Typora 会自动将本地路径(如 C:\Users\Admin\Desktop\1.png)替换为脚本返回的图床 URL。

AI 总结

深度总结:

本文是一篇面向开发者与高效笔记用户的实战型技术博客 ,聚焦于提升 Markdown 写作工作流的自动化水平。核心目标是打通 Typora 编辑器与自托管图床(Lsky Pro)之间的无缝上传链路,消除手动上传、复制链接、替换路径等重复性操作。

文章并非泛泛而谈"Python 脚本",而是深度结合 Typora 的定制上传机制规范(如严格的 Stdout 格式要求、多图参数传递方式、环境路径适配),提供可即用、可调试、可复用的生产级脚本。其价值体现在三个层面:

  1. 工程化集成思维:将独立脚本封装为编辑器原生功能,实现 IDE/编辑器级自动化,体现"工具即服务"的现代开发实践;
  2. 鲁棒性设计意识:脚本包含异常捕获、路径校验、状态码判断、JSON 响应结构容错等细节,兼顾稳定性与用户体验;
  3. 跨平台可部署性:明确区分 Windows/macOS/Linux 的命令配置差异,并强调虚拟环境路径、权限、依赖管理等运维关键点,降低落地门槛。

此外,文中隐含了对本地优先(Local-First)内容创作范式的支持------用户仍在本地编辑、本地存储原始图片,仅在插入时按需上传,兼顾隐私、可控性与协作便捷性,契合知识工作者对数字资产主权的诉求。


核心关键词(标签):

#Typora #图床自动化 #LskyPro #Python脚本 #Markdown工作流

相关推荐
豆沙糕2 分钟前
Python异步编程从入门到实战:结合RAG流式回答全解析
开发语言·python·面试
乘凉~40 分钟前
【VideoCaptioner】开源音视频字幕自动识别工具
python
重生之我要成为代码大佬1 小时前
HuggingFace生态实战:从模型应用到高效微调
人工智能·python·大模型·huggingface·模型微调
爱睡懒觉的焦糖玛奇朵1 小时前
【工业级落地算法之人员摔倒检测算法详解】
人工智能·python·深度学习·神经网络·算法·yolo·目标检测
chushiyunen1 小时前
python实现skip-gram(跳词)示例
开发语言·python
爆更小哇1 小时前
Python接口测试:requests库实战指南
自动化·接口测试
Rabbit_QL2 小时前
sklearn Pipeline:特征工程和建模流水线
人工智能·python·sklearn
MoRanzhi12032 小时前
scikit-learn Lasso回归算法详解
python·机器学习·回归·scikit-learn·正则化·l1·lasso
财经资讯数据_灵砚智能2 小时前
全球财经资讯日报(日间)2026年4月2日
大数据·人工智能·python·语言模型·ai编程
Songgp10242 小时前
yolo26+qwen3.5大小模型协同AI分析系统
图像处理·人工智能·python