QR Code Scan & Generate
基于 qrcode 和 pyzbar 的二维码扫描和生成工具。
When to Use This Skill
当用户有以下请求时,应该激活此技能:
- "扫描这个二维码图片"
- "解码二维码"
- "读取二维码内容"
- "这个二维码是什么"
- "生成一个二维码"
- "创建二维码"
- "把这段文字转成二维码"
- "生成网址二维码"
- "生成 WiFi 二维码"
- "创建 WiFi 分享码"
- "解析 WiFi 二维码"
依赖安装
CODEBLOCK0
注意 :Windows 用户可能需要安装 Visual C++ Redistributable,详见 pyzbar 文档 。
支持的输入格式
扫描二维码输入
- 文件路径 :本地图片文件路径 URL :网络图片地址Base64 :Base64 编码的图片数据
生成二维码输出
- PNG 图片文件 :保存到指定路径 Base64 字符串 :返回 Base64 编码的图片
命令行使用
(注意:如果想要更快速和节省Token,你应该优先使用命令行的方式!)
扫描二维码
CODEBLOCK1
参数:
- input:图片路径、URL 或 base64 数据 INLINECODE1 :以 JSON 格式输出结果
生成二维码
CODEBLOCK2
参数:
- content:要编码的内容 INLINECODE3 :输出文件路径(可选,不指定则输出 base64) INLINECODE4 :二维码类型(text/url/wifi,默认 text)
生成 WiFi 二维码
CODEBLOCK3
参数:
- --ssid:WiFi 名称 INLINECODE6 :WiFi 密码 INLINECODE7 :加密类型(WPA/WEP/NONE,默认 WPA) INLINECODE8 :输出文件路径(可选)
Python API 使用
快速开始
CODEBLOCK4
从 Base64 扫描
CODEBLOCK5
从 URL 扫描
CODEBLOCK6
解析 WiFi 二维码
CODEBLOCK7
API Reference
scan_qrcode(input_data, input_type=None, format_json=False)
扫描并解码二维码图片。
参数:
参数 类型 必需 说明 INLINECODE10 INLINECODE11 是 图片路径、URL 或 base64 数据 INLINECODE12
str | 否 | 输入类型:
file/
url/
base64,自动检测 |
|
format_json |
bool | 否 | 是否返回 JSON 格式结果 |
返回值:
- str 或 dict:解码内容,多个二维码时返回列表
异常:
- FileNotFoundError:文件不存在 INLINECODE22 :无法解码二维码 INLINECODE23 :缺少依赖库
generate_qrcode(content, output_path=None, qr_type='text', size=10, border=4)
生成二维码图片。
参数:
参数 类型 必需 说明 INLINECODE25 INLINECODE26 是 要编码的内容 INLINECODE27
str | 否 | 输出文件路径,不指定则返回 base64 |
|
qr_type |
str | 否 | 二维码类型:
text/
url/
wifi |
|
size |
int | 否 | 二维码尺寸(每个模块的像素数) |
|
border |
int | 否 | 边框宽度(模块数) |
返回值:
- str:base64 编码的图片(未指定 outputpath 时) INLINECODE39 :保存到文件(指定 outputpath 时)
generate_wifi_qrcode(ssid, password, security='WPA', output_path=None, hidden=False)
生成 WiFi 配置二维码。
参数:
参数 类型 必需 说明 INLINECODE41 INLINECODE42 是 WiFi 名称 INLINECODE43
str | 是 | WiFi 密码 |
|
security |
str | 否 | 加密类型:
WPA/
WEP/
NONE |
|
output_path |
str | 否 | 输出文件路径 |
|
hidden |
bool | 否 | 是否隐藏网络 |
返回值:
parse_wifi_qrcode(content)
解析 WiFi 二维码内容。
参数:
参数 类型 必需 说明 INLINECODE56 INLINECODE57 是 二维码解码内容
返回值:
- dict:包含 ssid、password、security 的字典 INLINECODE62 :如果不是有效的 WiFi 二维码
最佳实践
1. 扫描二维码 :
- 确保图片清晰,分辨率足够
- 支持常见格式:PNG、JPEG、BMP、GIF
- 图片中可以有多个二维码,会全部返回
2. 生成二维码 :
- 内容越长,二维码越复杂
- 建议使用
size=10 以上保证可扫描性
- URL 类型会自动验证格式
3. WiFi 二维码 :
- 使用 WPA 加密最常见
- 密码可能包含特殊字符,会自动处理
- 扫描后手机可直接连接 WiFi
完整示例
CODEBLOCK8
二维码扫描与生成
基于 qrcode 和 pyzbar 的二维码扫描和生成工具。
何时使用此技能
当用户有以下请求时,应该激活此技能:
- 扫描这个二维码图片
- 解码二维码
- 读取二维码内容
- 这个二维码是什么
- 生成一个二维码
- 创建二维码
- 把这段文字转成二维码
- 生成网址二维码
- 生成 WiFi 二维码
- 创建 WiFi 分享码
- 解析 WiFi 二维码
依赖安装
bash
pip install qrcode pillow pyzbar
注意 :Windows 用户可能需要安装 Visual C++ Redistributable,详见 pyzbar 文档 。
支持的输入格式
扫描二维码输入
- 文件路径 :本地图片文件路径 URL :网络图片地址Base64 :Base64 编码的图片数据
生成二维码输出
- PNG 图片文件 :保存到指定路径 Base64 字符串 :返回 Base64 编码的图片
命令行使用
(注意:如果想要更快速和节省Token,你应该优先使用命令行的方式!)
扫描二维码
bash
python scripts/main.py scan [--format json]
参数:
- input:图片路径、URL 或 base64 数据 --format json:以 JSON 格式输出结果
生成二维码
bash
python scripts/main.py generate --output [--type text|url|wifi]
参数:
- content:要编码的内容 --output:输出文件路径(可选,不指定则输出 base64) --type:二维码类型(text/url/wifi,默认 text)
生成 WiFi 二维码
bash
python scripts/main.py wifi --ssid --password --security WPA --output
参数:
- --ssid:WiFi 名称 --password:WiFi 密码 --security:加密类型(WPA/WEP/NONE,默认 WPA) --output:输出文件路径(可选)
Python API 使用
快速开始
python
from scripts.main import scanqrcode, generate qrcode, generatewifi qrcode
扫描二维码
result = scan_qrcode(qrcode.png)
print(result) # 解码内容
生成文字二维码
generate
qrcode(Hello World, output path=output.png)
生成 URL 二维码
generate
qrcode(https://example.com, qr type=url, output
path=url qr.png)
生成 WiFi 二维码
generate
wifi qrcode(MyWiFi, password123, security=WPA, output
path=wifi qr.png)
从 Base64 扫描
python
from scripts.main import scan_qrcode
base64 字符串(支持带或不带 data:image 前缀)
result = scan_qrcode(data:image/png;base64,iVBORw0KGgo...)
或纯 base64
result = scan
qrcode(iVBORw0KGgo..., input type=base64)
从 URL 扫描
python
from scripts.main import scan_qrcode
result = scan_qrcode(https://example.com/qrcode.png)
解析 WiFi 二维码
python
from scripts.main import scanqrcode, parse wifi_qrcode
result = scanqrcode(wifi qr.png)
wifiinfo = parse wifi_qrcode(result)
print(wifi_info)
{ssid: MyWiFi, password: password123, security: WPA}
API 参考
scanqrcode(input data, inputtype=None, format json=False)
扫描并解码二维码图片。
参数:
参数 类型 必需 说明 inputdata str 是 图片路径、URL 或 base64 数据 inputtype
str | 否 | 输入类型:file/url/base64,自动检测 |
| format_json | bool | 否 | 是否返回 JSON 格式结果 |
返回值:
- str 或 dict:解码内容,多个二维码时返回列表
异常:
- FileNotFoundError:文件不存在 ValueError:无法解码二维码 ImportError:缺少依赖库
generateqrcode(content, output path=None, qr_type=text, size=10, border=4)
生成二维码图片。
参数:
参数 类型 必需 说明 content str 是 要编码的内容 output_path
str | 否 | 输出文件路径,不指定则返回 base64 |
| qr_type | str | 否 | 二维码类型:text/url/wifi |
| size | int | 否 | 二维码尺寸(每个模块的像素数) |
| border | int | 否 | 边框宽度(模块数) |
返回值:
- str:base64 编码的图片(未指定 outputpath 时) None:保存到文件(指定 outputpath 时)
generatewifi qrcode(ssid, password, security=WPA, output_path=None, hidden=False)
生成 WiFi 配置二维码。
参数:
参数 类型 必需 说明 ssid str 是 WiFi 名称 password
str | 是 | WiFi 密码 |
| security | str | 否 | 加密类型:WPA/WEP/NONE |
| output_path | str | 否 | 输出文件路径 |
| hidden | bool | 否 | 是否隐藏网络 |
返回值:
parsewifi qrcode(content)
解析 WiFi 二维码内容。
参数:
参数 类型 必需 说明 content str 是 二维码解码内容
返回值:
- dict:包含 ssid、password、security 的字典 None:如果不是有效的 WiFi 二维码
最佳实践
1. 扫描二维码 :
- 确保图片清晰,分辨率足够
- 支持常见格式:PNG、JPEG、BMP、GIF
- 图片中可以有多个二维码,会全部返回
2. 生成二维码 :
- 内容越长,二维码越复杂
- 建议使用 size=10 以上保证可扫描性
- URL 类型会自动验证格式
3. WiFi 二维码 :
- 使用 WPA 加密最常见
- 密码可能包含特殊字符,会自动处理
- 扫描后手机可直接连接 WiFi
完整示例
python
from scripts.main import scanqrcode, generate qrcode, generatewifi qrcode, parsewifi qrcode
生成并扫描 URL 二维码
generate
qrcode(https://github.com, output path=github_qr.png)
result = scan
qrcode(github qr.png)
print(f扫描结果: {result})
生成 WiFi 二维码
generate
wifi qrcode(
ssid=MyHomeWiFi,
password=MySecurePassword123,
security=WPA,
output
path=wifi qr.png
)
解析 WiFi 二维码
wifi
content = scan qrcode(wifi_qr.png)
wifi
info = parse wifi
qrcode(wifi content)
print(fWiFi 信息: SSID={wifi
info[ssid]}, 密码={wifi info[password]})
从 base64 生成并获取 base64 输出
base64
qr = generate qrcode(Hello World)
print(fBase64 QR: {base64_qr[:50]}...)
扫描网络图片
result = scan_qrcode(https://example.com/qrc