jianzhihuixiang/alacarte-novel-website/data/update_chapters.py

77 lines
3.4 KiB
Python
Raw Normal View History

#!/usr/bin/env python3
# -*- coding: utf-8 -*-
import json
import os
import re
# 章节标题映射根据内容生成合适的subtitle
subtitle_map = {
1: '初入阿拉德', 2: '剑士之路', 3: '鬼手觉醒', 4: '格兰之森', 5: '牛头巨兽',
6: '幽暗密林', 7: '猛毒雷鸣', 8: '冰霜幽暗', 9: '烈焰格拉卡', 10: '暗黑雷鸣',
11: '天空之城', 12: '龙人之塔', 13: '人偶玄关', 14: '石巨人塔', 15: '黑暗玄廊',
16: '城主宫殿', 17: '光之城主', 18: '西海岸', 19: '天帷巨兽', 20: '神殿外围',
21: '树精丛林', 22: '炼狱', 23: '极昼', 24: '第一脊椎', 25: '第二脊椎',
26: 'GBL教', 27: '奥菲利亚', 28: '阿法利亚', 29: '蜘蛛洞穴', 30: '浅栖之地',
31: '摩根之谜', 32: '暗精灵', 33: '熔岩穴', 34: '暗影迷宫', 35: '邪龙封印',
36: '雪山之旅', 37: '冰心少年', 38: '山脊', 39: '利库天井', 40: '白色废墟',
41: '布万加', 42: '敏泰', 43: '班图族', 44: '斯卡萨', 45: '冰雪宫殿',
46: '斯顿雪域', 47: 'GBL女神殿', 48: '树精繁殖地', 49: '堕落之殿', 50: '诺斯玛尔',
51: '盗贼团', 52: '哈穆林', 53: '鼠王', 54: '迷乱之村', 55: '血蝴蝶',
56: '帕丽丝', 57: '月光酒馆', 58: '索西雅', 59: '死亡之塔', 60: '迷惘之塔',
61: '绝望之塔', 62: '莎兰', 63: '西海岸风云', 64: '暗精灵战争', 65: '克伦特',
66: '暗黑城', 67: '暗影迷宫', 68: '无头骑士', 69: '悲鸣洞穴', 70: '启程天界',
71: '根特外围', 72: '卡勒特', 73: '皇女艾丽婕', 74: '泽丁', 75: '马琳',
76: '夜间袭击', 77: '补给线阻断', 78: '追击歼灭', 79: '夜间奇袭', 80: '夺回东门',
81: '夺回南门', 82: '北门反击', 83: '根特防御', 84: '卡勒特总部', 85: '兰蒂卢斯',
86: '海上列车', 87: '莫斯提马', 88: '斯曼工业', 89: '安徒恩', 90: '攻坚战',
91: '使徒陨落'
}
updated_count = 0
for i in range(1, 92):
# 确定文件名格式
if i <= 9:
filename = f'chapter-0{i}.json'
else:
filename = f'chapter-{i}.json'
filepath = os.path.join('.', filename)
if not os.path.exists(filepath):
print(f'文件不存在: {filename}')
continue
with open(filepath, 'r', encoding='utf-8') as f:
data = json.load(f)
# 检查是否需要更新
needs_update = False
# 添加subtitle
if 'subtitle' not in data or not data['subtitle']:
data['subtitle'] = subtitle_map.get(i, f'{i}')
needs_update = True
# 添加desc从content提取前100字符
if 'desc' not in data or not data['desc']:
content = data.get('content', '')
# 提取第一段,去除换行和多余空格
first_para = content.split('\n')[0].strip()
# 清理内容,只保留纯文本
first_para = re.sub(r'["\'\n\t]', '', first_para)
# 截取前100字符
desc = first_para[:100] + '...' if len(first_para) > 100 else first_para
data['desc'] = desc
needs_update = True
if needs_update:
with open(filepath, 'w', encoding='utf-8') as f:
json.dump(data, f, ensure_ascii=False, indent=2)
updated_count += 1
print(f'已更新: {filename}')
else:
print(f'无需更新: {filename}')
print(f'\n总共更新了 {updated_count} 个文件')