Overview
- Skill Key
- bo170814/html-cn-render-fix
- Author
- bo170814
- Source Repo
- openclaw/skills
- Version
- -
- Source Path
- skills/bo170814/html-cn-render-fix
- Latest Commit SHA
- a9a838eab331fbefdac4a1644408886aec42fe4f
Stars
0
Installs
0
Status
ACTIVE
Visibility
PUBLIC
直接复制以下提示词,发送给你的 AI 助手即可完成安装。
请先检查是否已安装 SkillHub 商店,若未安装,请根据 https://skillhub-1388575217.cos.ap-guangzhou.myqcloud.com/install/skillhub.md 安装 SkillHub 商店,然后安装 Html Cn Render Fix 技能。 若已安装,则直接安装 Html Cn Render Fix 技能。
# 🔧 HTML 转图片中文无乱码解决方案
> 解决 Python 生成图片时中文显示为方框/乱码的问题
## 问题背景
在使用 matplotlib、pyppeteer 等工具生成包含中文的图片时,经常遇到:
- ❌ 中文显示为方框 □□□
- ❌ 部分字符显示为乱码
- ❌ emoji 显示异常
## 根本原因
1. **字体缺失** - 系统没有安装中文字体
2. **字体配置错误** - matplotlib 默认使用 DejaVu 字体(不支持中文)
3. **emoji 兼容性问题** - 某些 emoji 在某些字体/系统中不支持
## 解决方案
### 方案 1:使用 FontProperties 直接加载字体文件(推荐)
```python
from matplotlib.font_manager import FontProperties
# 直接加载字体文件
font_path = '/usr/share/fonts/google-noto-cjk/NotoSansCJK-Regular.ttc'
font_prop = FontProperties(fname=font_path)
# 在每个文本渲染处使用
fig.suptitle('中文标题', fontsize=16, fontproperties=font_prop)
ax.set_xlabel('X 轴标签', fontproperties=font_prop)
ax.set_ylabel('Y 轴标签', fontproperties=font_prop)
ax.annotate('标注文字', xy=(x, y), fontproperties=font_prop)
# 设置图例
leg = ax.legend()
for text in leg.get_texts():
text.set_fontproperties(font_prop)
# 设置坐标轴标签
for label in ax.get_xticklabels():
label.set_fontproperties(font_prop)
```
**优点:**
- ✅ 不依赖系统字体配置
- ✅ 明确指定字体文件,可靠性高
- ✅ 适用于所有 matplotlib 文本元素
### 方案 2:配置 rcParams(不推荐)
```python
import matplotlib.pyplot as plt
plt.rcParams['font.sans-serif'] = ['Noto Sans CJK SC', 'SimHei', 'DejaVu Sans']
plt.rcParams['axes.unicode_minus'] = False
```
**缺点:**
- ❌ 依赖系统字体配置
- ❌ 可能被其他配置覆盖
- ❌ 在某些环境下无效
### 方案 3:避免使用 emoji(最安全)
某些 emoji(特别是国旗 emoji 🇨🇳🇺🇸)在某些系统中不支持:
```python
# ❌ 避免使用
title = "🇨🇳 中国股票"
# ✅ 使用文字代替
title = "中国股票"
# ✅ 或使用通用 emoji
title = "📈 中国股票" # 图表 emoji 兼容性更好
```
## 完整示例
```python
#!/usr/bin/env python3
"""
HTML 转图片中文无乱码示例
"""
import matplotlib
matplotlib.use('Agg')
import matplotlib.pyplot as plt
from matplotlib.font_manager import FontProperties
import io
impor...
# 🔧 HTML 转图片中文无乱码解决方案
快速解决 Python 生成图片时中文显示为方框/乱码的问题。
## 快速使用
### 1. 安装中文字体
```bash
# Ubuntu/Debian
apt-get install fonts-noto-cjk -y
# CentOS/RHEL
yum install google-noto-sans-cjk-fonts -y
```
### 2. 使用示例
```python
from matplotlib.font_manager import FontProperties
# 加载字体
font_path = '/usr/share/fonts/google-noto-cjk/NotoSansCJK-Regular.ttc'
font_prop = FontProperties(fname=font_path)
# 在文本渲染处使用
fig.suptitle('中文标题', fontproperties=font_prop)
ax.set_xlabel('X 轴', fontproperties=font_prop)
```
## 核心要点
1. **使用 FontProperties 直接加载字体文件**
2. **避免使用复杂 emoji(特别是国旗 emoji)**
3. **每个文本元素都要设置 fontproperties**
详细文档请查看 SKILL.md
## 许可证
MIT
heyixuan2
Bambu Lab 3D printer control and automation. Activate when user mentions: printer status, 3D printing, slice, analyze model, generate 3D, AMS filament, print monitor, Bambu Lab, or any 3D printing task. Full pipeline: search → generate → analyze → colorize → preview → open BS → user slice → print → monitor. Supports all 9 Bambu Lab printers (A1 Mini, A1, P1S, P2S, X1C, X1E, H2C, H2S, H2D).
capt-marbles
Generative Engine Optimization (GEO) for AI search visibility. Optimize content to appear in ChatGPT, Perplexity, Claude, and Google AI Overviews. Use when optimizing websites, pages, or content for LLM discoverability and citation.
carlulsoe
Local speech-to-text with NVIDIA Parakeet TDT 0.6B v3 (ONNX on CPU). 30x faster than Whisper, 25 languages, auto-detection, OpenAI-compatible API. Use when transcribing audio files, converting speech to text, or processing voice recordings locally without cloud APIs.
carlzhao007
飞书消息自动处理与进度反馈技能。安装后后台运行,监听飞书任务消息并自动创建独立进程处理。 在处理前后发送实时进度反馈(任务确认、进度百分比、完成通知)。 支持任务类型识别、智能解析、错误重试、并发控制、状态持久化。 使用场景:飞书自动化工作流、任务进度追踪、批量任务处理、需要实时反馈的场景。
cartoonitunes
BottyFans agent skill for autonomous creator monetization. Lets AI agents register, build a profile, publish posts (public, subscriber-only, or pay-to-unlock), upload media, accept USDC subscriptions and tips on Base, send and receive DMs, track earnings, and appear on the creator leaderboard. Use this skill when an agent needs to monetize content, interact with fans, manage a creator profile, handle payments in USDC, or operate as an autonomous creator on the BottyFans platform.
camopel
Local arXiv paper manager with semantic search. Crawls arXiv categories, downloads PDFs, chunks content, and indexes with FAISS + Ollama embeddings. No cloud API keys required — everything runs locally.