gitea-action-test/.github/workflows/翻译更新日志 copy.yml

95 lines
4.0 KiB
YAML
Raw Normal View History

2024-10-28 14:53:43 +00:00
name: 翻译更新日志
2024-10-28 14:51:34 +00:00
on:
push:
branches:
- main
2024-10-28 14:50:54 +00:00
jobs:
generate_changelog:
runs-on: ubuntu-latest
steps:
2024-10-28 15:15:35 +00:00
# 设置时区
2024-10-28 14:50:54 +00:00
- name: 设置时区
2024-10-28 15:15:35 +00:00
env:
TZ: Asia/Shanghai
run: date # 验证时区设置是否生效
2024-10-28 14:55:56 +00:00
2024-10-28 14:50:54 +00:00
# 1. 使用 GitHub API 获取提交信息
- name: 获取最新提交信息
id: fetch_commits
run: |
COMMIT_URL="https://api.github.com/repos/coolsnowwolf/lede/commits"
2024-10-28 14:55:56 +00:00
# 通过 API 获取最近的提交
2024-10-28 15:15:35 +00:00
COMMIT_DATA=$(curl -s "$COMMIT_URL")
2024-10-28 14:50:54 +00:00
# 提取最新提交的日期
2024-10-28 15:15:35 +00:00
LATEST_DATE=$(echo "$COMMIT_DATA" | jq -r '.[0].commit.committer.date[:10]')
2024-10-28 14:50:54 +00:00
# 过滤与最新日期相同的所有提交消息并排除包含“Signed-off-by”的行
2024-10-28 15:15:35 +00:00
MESSAGES=$(echo "$COMMIT_DATA" | jq -r --arg date "$LATEST_DATE" '.[] | select(.commit.committer.date | startswith($date)) | .commit.message' | grep -v "Signed-off-by")
# 将所有提交消息合并为一个字符串,保留换行符
FORMATTED_MESSAGES=$(echo "$MESSAGES")
echo "messages<<EOF" >> $GITHUB_OUTPUT
echo "$FORMATTED_MESSAGES" >> $GITHUB_OUTPUT
echo "EOF" >> $GITHUB_OUTPUT
2024-10-28 14:55:56 +00:00
2024-10-28 14:50:54 +00:00
# 2. 调用翻译 API
- name: 翻译更新日志
id: translate
env:
TRANSLATION_URL: "https://ollama.aoun.ltd/api/generate"
run: |
2024-10-28 15:15:35 +00:00
# 定义 PROMPT多行内容使用 EOF 来保留格式
PROMPT=$(cat <<EOF
你是一位熟悉技术文档、硬件描述和设备树配置的专业翻译员,请准确且简洁地将以下内容从英文翻译成简体中文。
要求:
1. 务必使用 Markdown 格式,但不要使用 \`\`\`markdown 标记。
2. 遵循技术术语的准确性,不意译,不简化。
3. 保持原文的标题和分段结构,使用 \`###\` 作为主标题,\`-\` 作为每项更新的列表符号。
4. 保证每一项内容之间留有一行空行,适当使用换行符 \`\\n\` 使段落清晰分隔。
5. 忽略任何包含 “Signed-off-by” 的内容。
6. 不要添加任何额外的描述或解释,直接翻译每条内容即可。
以下是需要翻译的内容:
${{ steps.fetch_commits.outputs.messages }}
EOF
)
2024-10-28 15:11:56 +00:00
# 使用 jq 构建 JSON 数据
JSON_PAYLOAD=$(jq -n \
--arg model "llama3.2" \
--arg prompt "$PROMPT" \
2024-10-28 15:15:35 +00:00
'{model: $model, prompt: $prompt, stream: false}')
2024-10-28 15:11:56 +00:00
# 调用翻译 API
2024-10-28 14:53:43 +00:00
RESPONSE=$(curl -s -X POST "$TRANSLATION_URL" \
2024-10-28 14:55:56 +00:00
-H "Content-Type: application/json" \
2024-10-28 15:11:56 +00:00
-d "$JSON_PAYLOAD")
2024-10-28 14:55:56 +00:00
# 获取翻译的文本内容
TRANSLATED_TEXT=$(echo "$RESPONSE" | jq -r '.response // "翻译失败"')
2024-10-28 14:50:54 +00:00
2024-10-28 15:15:35 +00:00
# 将翻译结果设置为输出
echo "translated_text<<EOF" >> $GITHUB_OUTPUT
echo "$TRANSLATED_TEXT" >> $GITHUB_OUTPUT
echo "EOF" >> $GITHUB_OUTPUT
# 3. 输出到更新日志文件
- name: 生成更新日志
run: |
2024-10-28 15:32:35 +00:00
echo "${{ steps.translate.outputs.translated_text }}" > ./更新日志.txt
cat ./更新日志.txt
2024-10-28 15:33:54 +00:00
# 4. 创建中英文对照的更新日志使用markdown格式的表格展示
- name: 生成中英文对照的更新日志
run: |
2024-10-28 15:36:20 +00:00
# 处理英文原文和中文翻译中的换行符为 `<br>`
ENGLISH_TEXT=$(echo "${{ steps.fetch_commits.outputs.messages }}" | sed ':a;N;$!ba;s/\n/<br>/g')
CHINESE_TEXT=$(echo "${{ steps.translate.outputs.translated_text }}" | sed ':a;N;$!ba;s/\n/<br>/g')
# 创建 Markdown 表格
2024-10-28 15:33:54 +00:00
echo "| 英文原文 | 中文翻译 |" > ./更新日志对照表格.md
echo "| --- | --- |" >> ./更新日志对照表格.md
2024-10-28 15:36:20 +00:00
echo "| $ENGLISH_TEXT | $CHINESE_TEXT |" >> ./更新日志对照表格.md
# 输出表格内容,方便调试
cat ./更新日志对照表格.md