node的readDirFiles、readFileSync 的一些实操脚本

健儿健儿 -
node的readDirFiles、readFileSync 的一些实操脚本

1、读取文件夹里面,所有是js的文件

const fs = require('fs');
const path = require('path');

// 读取文件夹中的所有文件
function readDirFiles(dir, fileList) {
  const files = fs.readdirSync(dir);
  fileList = fileList || [];

  files.forEach(function(file) {
    const filePath = path.join(dir, file);
    if (fs.statSync(filePath).isDirectory()) {
      fileList = readDirFiles(filePath, fileList);
    } else {
      if (filePath.endsWith('.js')) {
        fileList.push(filePath);
      }
    }
  });

  return fileList;
}

// 读取指定文件夹中的所有JS文件
const fileList = readDirFiles('./src');
console.log(fileList);

用到的node的api有:
readdirSync、statSync、isDirectory、readDirFiles、endsWith
用到算法:递归

2、用node的api实现一个脚本,读取某一个文件夹里所有的js代码,并读取输出到一个指定的文件里。

const fs = require('fs');
const path = require('path');

// 读取文件夹中的所有文件
function readDirFiles(dir, fileList) {
  const files = fs.readdirSync(dir);
  fileList = fileList || [];

  files.forEach(function(file) {
    const filePath = path.join(dir, file);
    if (fs.statSync(filePath).isDirectory()) {
      fileList = readDirFiles(filePath, fileList);
    } else {
      if (filePath.endsWith('.js')) {
        const content = fs.readFileSync(filePath, { encoding: 'utf-8' });
        fileList.push({ path: filePath, content });
      }
    }
  });

  return fileList;
}

// 将JS文件写入文件
function writeFile(fileList, outputPath) {
  const stream = fs.createWriteStream(outputPath);

  fileList.forEach(file => {
    const jsCode = `// File Path: ${file.path}
${file.content}

`;
    stream.write(jsCode);
  });

  stream.end();
}

// 读取指定文件夹中的所有JS文件,并将JS代码写入指定输出文件中
const fileList = readDirFiles('/path/to/your/folder');
writeFile(fileList, '/path/to/your/output.js');

用到的api:
readdirSync、statSync、isDirectory、endsWith、readFileSync、createWriteStream

可以看出,对比问题1,多用了两个api,读取文件和写入文件
readFileSync、createWriteStream
算法:递归

特别申明:本文内容来源网络,版权归原作者所有,如有侵权请立即与我们联系(cy198701067573@163.com),我们将及时处理。

Tags 标签

前端javascriptnode.js

扩展阅读

加个好友,技术交流

1628738909466805.jpg