Files
online_sys/frontend_智能开发/updateAvatars.cjs
KQL a7242f0c69 Initial commit: 教务系统在线平台
- 包含4个产业方向的前端项目:智能开发、智能制造、大健康、财经商贸
- 已清理node_modules、.yoyo等大文件,项目大小从2.6GB优化至631MB
- 配置完善的.gitignore文件

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-12 18:16:55 +08:00

77 lines
2.8 KiB
JavaScript
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

const fs = require('fs');
// 新的头像URL选择
const newAvatars = {
// 袁嘉宇 - 使用id=15的头像不同风格
'袁嘉宇': 'https://ddcz-1315997005.cos.ap-nanjing.myqcloud.com/static/avatar/douyin/54461d443f4927823b56661d0aa6205b.jpg',
// 第1名 - 许思涵 - 使用id=10的头像
'许思涵': 'https://ddcz-1315997005.cos.ap-nanjing.myqcloud.com/static/avatar/douyin/3255be536cf8fb3ddece6cb2733a0c6b.jpg',
// 第2名 - 沈子墨 - 使用id=12的头像
'沈子墨': 'https://ddcz-1315997005.cos.ap-nanjing.myqcloud.com/static/avatar/douyin/377cc7767c3c9401c3987c844ce73e4b.jpg',
// 第3名 - 冯欣怡 - 使用id=14的头像
'冯欣怡': 'https://ddcz-1315997005.cos.ap-nanjing.myqcloud.com/static/avatar/douyin/457cfa8e557879e14d54f13dc226a11e.jpg'
};
// 读取mockData.js
const mockDataPath = './src/data/mockData.js';
let mockDataContent = fs.readFileSync(mockDataPath, 'utf-8');
// 备份
const backupPath = `${mockDataPath}.backup_avatars_${new Date().toISOString().replace(/[:.]/g, '-')}`;
fs.writeFileSync(backupPath, mockDataContent);
console.log(`✅ 已创建备份:${backupPath}`);
// 更新user中的袁嘉宇头像
mockDataContent = mockDataContent.replace(
/user:\s*{[\s\S]*?avatar:\s*"[^"]+"/,
(match) => {
return match.replace(
/avatar:\s*"[^"]+"/,
`avatar: "${newAvatars['袁嘉宇']}"`
);
}
);
// 更新classRanking中的头像
for (const [name, url] of Object.entries(newAvatars)) {
// 使用更精确的正则表达式来匹配每个学生的数据块
const namePattern = new RegExp(
`(name|studentName):\\s*"${name}"[\\s\\S]*?avatar:\\s*"[^"]+"`,
'g'
);
mockDataContent = mockDataContent.replace(namePattern, (match) => {
return match.replace(/avatar:\s*"[^"]+"/, `avatar: "${url}"`);
});
}
// 同样需要更新ClassRankModal组件中的头像映射
const modalPath = './src/components/ClassRankModal/index.jsx';
let modalContent = fs.readFileSync(modalPath, 'utf-8');
// 备份ClassRankModal
const modalBackup = `${modalPath}.backup_avatars_${new Date().toISOString().replace(/[:.]/g, '-')}`;
fs.writeFileSync(modalBackup, modalContent);
// 更新ClassRankModal中的头像映射
for (const [name, url] of Object.entries(newAvatars)) {
const casePattern = new RegExp(
`case\\s*"${name}":[\\s\\S]*?avatarUrl\\s*=\\s*"[^"]+"`,
'g'
);
modalContent = modalContent.replace(casePattern, (match) => {
return match.replace(/avatarUrl\s*=\s*"[^"]+"/, `avatarUrl = "${url}"`);
});
}
// 写回文件
fs.writeFileSync(mockDataPath, mockDataContent);
fs.writeFileSync(modalPath, modalContent);
console.log('✅ 头像更新完成!');
console.log('\n更新的头像');
console.log('- 袁嘉宇(个人信息): 新头像');
console.log('- 许思涵第1名: 新头像');
console.log('- 沈子墨第2名: 新头像');
console.log('- 冯欣怡第3名: 新头像');