【nodejs脚本】为文件夹中的所有node项目执行命令 npm install 并收集error日志

目录 im 下有很多的node项目,我需要批量为这些项目执行 npm install,另外npm的error信息需要单独收集至log文件中

复制代码
var fs = require('fs');
var util = require('util');
var exec = util.promisify(require('child_process').exec);

var projectsDirectory = '.';
var logFilePath = './npm_install_errors.log'; // 更改为您的日志文件路径
var br = `⬆⬆⬆ ---------------------------------------------------------------- ⬆⬆⬆ \n\n`;

async function runNpmInstall(projectDir) {
  try {
    var errorContent = '';
    var { stdout, stderr } = await exec('npm install', { cwd: projectDir });
    console.log(`在 ${projectDir} 执行 'npm install' 完成。`);
    console.log(br);
    if (stdout) console.log(stdout);
    if (stderr) {
       errorContent = `在 ${projectDir} 执行 'npm install' 时出错: >>> \n ${stderr} \n` + br;
      console.error( errorContent );
      
      // 将错误信息写入日志文件
      fs.appendFile(logFilePath, errorContent, (err) => {
        if (err) console.error(`无法追加到日志文件: ${err}`);
      });
    }
  } catch (error) {
    errorContent =  `在 ${projectDir} 执行 'npm install' 时出错: >>> \n ${error.message} \n` + br;

    // 将错误信息追加到日志文件
    fs.appendFile(logFilePath,errorContent, (err) => {
      if (err) console.error(`无法追加到日志文件: ${err}`);
    });
  }
}

async function main() {
  try {
    // 读取目录下的所有文件夹
    var projectFolders = await fs.promises.readdir(projectsDirectory, { withFileTypes: true });

    // 遍历每个文件夹
    for (var folder of projectFolders) {
      if (folder.isDirectory()) {
        var projectDir = `${projectsDirectory}/${folder.name}`;
        var packageJsonPath = `${projectDir}/package.json`;

        // 检查是否存在 package.json 文件
        if (fs.existsSync(packageJsonPath)) {
          console.log(`在 ${projectDir} 执行 'npm install'...`);
          await runNpmInstall(projectDir);
        } else {
          console.log(`在 ${projectDir} 找不到 package.json 文件,跳过。\n\n`);
        }
      }
    }
  } catch (error) {
    var errorContent = `发生错误: ${error.message} \n` + br;;

    // 将错误信息追加到日志文件
    fs.appendFile(logFilePath, errorContent, (err) => {
      if (err) console.error(`无法追加到日志文件: ${err}`);
    });
  }
}

main();
相关推荐
来杯三花豆奶4 分钟前
Vue3 Pinia 从入门到精通
前端·javascript·vue.js
卡布叻_星星25 分钟前
Docker之Nginx前端部署(Windows版-x86_64(AMD64)-离线)
前端·windows·nginx
LYFlied25 分钟前
【算法解题模板】-解二叉树相关算法题的技巧
前端·数据结构·算法·leetcode
weibkreuz28 分钟前
React的基本使用@2
前端·javascript·react.js
于是我说32 分钟前
前端JavaScript 项目中 获取当前页面滚动位置
开发语言·前端·javascript
GISer_Jing32 分钟前
AI在前端开发&营销领域应用
前端·aigc·音视频
Hao_Harrision41 分钟前
50天50个小项目 (React19 + Tailwindcss V4) ✨ | DragNDrop(拖拽占用组件)
前端·react.js·typescript·tailwindcss·vite7
来杯三花豆奶1 小时前
Vue 2.0 Mixins 详解:从原理到实践的深度解析
前端·javascript·vue.js
code_YuJun1 小时前
脚手架开发工具——dotenv
前端
vipbic1 小时前
Strapi 5 怎么用才够爽?这款插件带你实现“建站自由”
后端·node.js