Bỏ qua đến nội dung

AI提问

Chờ xử lý #anki #addon
https://github.com/abc123sm/anki_aitiwen
27/11/2025

Cách tải addon AI提问

Bạn có thể tải addon bằng một trong hai cách sau:

Click nút Copy bên dưới để copy code vào clipboard

724150025

Sau đó mở Anki → Tools → Add-ons → Get Add-ons → Dán code → OK

Mở trang addon trên AnkiWeb và tìm mã code ở cuối trang

Mở trên AnkiWeb

Cuộn xuống cuối trang AnkiWeb, tìm dòng có mã code 724150025 và copy

Mô tả chi tiết

Anki 插件:AI提问

本插件允许你在 Anki 复习卡片时,一键调用 Google Gemini AI(或者其他AI),对日语句子进行详细的语法和词汇解析(或者问别的问题,可以设置自己设置上下文与prompt),并将结果自动填入指定字段(需要配合1020366288插件)。

AI代码警告

本插件所有代码均为AI生成,人为修改不到1%

功能特性 一键调用:在卡片模板中添加一个按钮,即可快速向AI提问。 高度可配置:支持自定义 API Key、模型、系统提示词、上下文对话等。 智能上下文:支持配置多轮对话作为上下文,让AI的回答更符合你的期望。 无缝体验:优化了与 Edit Field During Review 插件的兼容性,更新解析后无需刷新卡片。 自动创建配置:首次使用时会自动生成配置文件,简化初始设置。 安装与配置

安装插件:

通过 AnkiWeb 页面下载,或使用代码 [724150025] 安装本插件。 通过 AnkiWeb 页面下载,或使用代码 [1020366288] 安装依赖插件Edit Field During Review。

获取 Gemini API Key(或者别的AI的API):

访问 Google AI Studio。 点击 “Create API key” 生成你的密钥。 其他AI大概也行,自己想办法搞

配置插件:

在 Anki 主界面,点击菜单栏的 工具 > AI提问配置。 将你获取的 API Key 填入 API Key 字段。 根据你的卡片模板,设置 提问字段 (例如:Expression) 和 回答字段 (例如:Edit)。 (可选)根据你的需求修改系统提示词和其他参数。 点击 “保存”。

在卡片模板中添加按钮:

这是必须的步骤!你需要手动在你的卡片模板中添加一个按钮来触发AI。 打开 Anki 的 工具 > 管理笔记类型,选择你使用的笔记类型,然后点击 卡片…。 在“正面模板”或“背面模板”的 HTML 代码中,找到一个合适的位置,粘贴以下代码: <button onclick=“pycmd(‘aiGenerate’)” style=“padding: 10px 1px; background: #3d8b40; font-size: 14px;“>AI提问</button>

示例模板:如果你想在看到答案后才提问,可以把代码加在“背面模板”的 {{AI解析}} 字段旁边。 Front Template <!— <div>{{kanji:am-highlighted}}</div>

复制Expression字段 <button class=“copy-btn” onclick=“copyReading(this)” data-copy-anniu=“{{Expression}}“>复制</button> —> {{Audio}} <div>{{Snapshot}}</div>

<script> function copyReading(button) { // 从按钮的anniu属性获取特定字段的内容 const readingText = button.getAttribute(‘data-copy-anniu’);

// 创建临时textarea元素 const textarea = document.createElement(‘textarea’); textarea.value = readingText; document.body.appendChild(textarea);

// copy textarea.select(); document.execCommand(‘copy’);

// delete document.body.removeChild(textarea);

// update const originalText = button.textContent; button.textContent = ‘搞掂’; button.classList.add(‘copied’); } </script>

Back Template <button class=“copy-btn” onclick=“copyReading(this)” data-copy-anniu=“{{Expression}}“>复制</button> <div>{{furigana:am-highlighted}}</div> <div>{{Snapshot}}</div> <div style=‘font-size: 40px’>{{edit:Meaning}}</div> <div style=‘font-size: 25px; text-align:start’>{{edit:Edit}}</div> <button onclick=“pycmd(‘aiGenerate’)” style=“padding: 10px 1px; background: #3d8b40; font-size: 14px;“>AI提问</button>

Styling .card { font-family: arial; font-size: 50px; text-align: center; color: #CDC8B1; background-color: #25390c;##f1e5c9; } .card.nightMode { font-family: arial;//arial font-size: 50px; text-align: center; color: #8B8878; #background-color: #25390c; }

.expression{ font-size: 40px; } [morph-status=unknown] { color: red; } [morph-status=learning] { color: #1E90FF; } [morph-status=known] { color: green; }

.copy-btn { padding: 10px 1px; background-color: #3d8b40; font-size: 18px; /* 可用 !important增大字体 */ float: left; }

.copy-btn.copied { background-color: #666; }

效果 问题反馈

如果你遇到任何问题或有功能建议,欢迎到本项目的 GitHub Issues 页面提交。 或者 这个TG频道。

更新

25/11/28 修改了设置的逻辑,更新插件后不需要重新配置config,并且修改了报错时回复的逻辑,API调用错误不会再返回完整的api请求,而是会把apikey遮蔽,避免直播学习时漏出apikey,然后还有一些跟回报相关的逻辑也改了


Screenshots

图片

图片


Liên kết hỗ trợ