Node.js 节点:尝试重命名目录中的每个文件会跳过一些

Node.js 节点:尝试重命名目录中的每个文件会跳过一些,node.js,asynchronous,fs,Node.js,Asynchronous,Fs,我试图遍历一个目录(及其所有子目录),并重命名(移动)每个图像(如果它是.jpg文件)。我认为我的代码是正确的。我使用异步重命名和递增计数器来增加文件名。但由于某种原因,在我对四个子文件夹的测试中,只有一半的图像被重命名。我不知道这是为什么,因为我只是在回调文件(一旦成功重命名图像)时递增,并检查控制台列出调用rename的每个文件 var fs = require('fs'); var filePrefix = 'new_Images'; var folderName = 'changed';

我试图遍历一个目录(及其所有子目录),并重命名(移动)每个图像(如果它是
.jpg
文件)。我认为我的代码是正确的。我使用异步重命名和递增计数器来增加文件名。但由于某种原因,在我对四个子文件夹的测试中,只有一半的图像被重命名。我不知道这是为什么,因为我只是在回调文件(一旦成功重命名图像)时递增,并检查控制台列出调用
rename
的每个文件

var fs = require('fs');
var filePrefix = 'new_Images';
var folderName = 'changed';
var counter = 0;

function examine (path) {
  fs.readdir(path, function (err, files) {
    files.forEach(function (file) {

      var oldPath = path + file;

      fs.stat(oldPath, function (err, stats) {
        if (stats.isDirectory()) {
          examine(oldPath + '/');
        } else {

          var suffix = oldPath.substr(oldPath.length - 3);

          if (suffix === 'jpg') {
            fs.rename(oldPath, './' + folderName + '/' + filePrefix + counter + '.jpg', function (e) {
              if (e) throw new Error('something bad happened');
              console.log('Renamed a .jpg file');
              console.log(oldPath);
              console.log(counter);
              counter++;
            });
          } else if (suffix === 'png') {
            fs.rename(oldPath, './' + folderName + './' + filePrefix + counter + '.png', function (e) {
              if (e) throw new Error('something bad happened');
              console.log('Renamed a .png file');
              console.log(oldPath);
              console.log(counter);
              counter++;
            });
          } 
        }
      });
    });
  });
}

examine('./');

此代码将记录每个文件都已重命名,并且所有文件都将被删除,但实际上只有一半文件被移动(重命名)到新文件夹中

我猜这些文件被过度写入

因为异步调用是在重命名时进行的,所以在进行异步调用之前,而不是在成功重命名之后,应该增加
计数器。由于异步调用中没有顺序,所以有一半的调用可能是在使用相同名称成功重命名操作之前进行的

您可以通过记录文件名来验证这一点:

if (suffix === 'jpg') {
  console.log('renaming with file name ' + filePrefix + counter + '.jpg');
  fs.rename(oldPath, './' + folderName + '/' + filePrefix + counter + '.jpg', function (e) {
    ...
  });
} else if (suffix === 'png') {
  console.log('renaming with file name ' + filePrefix + counter + '.png');
  fs.rename(oldPath, './' + folderName + './' + filePrefix + counter + '.png', function (e) {
    ...
  });
}

该计划满足所有要求

var fs = require('fs'),
path = require('path');

var oldPath = 'G:\\oldPath\\oldPath';
var newPath = 'G:\\newPath\\newPath\\';
var ext = 'jpg';
var newPrefix = 'newPrefix';

var myFun = function(mypath) {
 fs.readdir(mypath, function(error, files) {
     if (error)
         console.log('error ' + error.code + ' : ' + error.message);
     else {
         files.map(function(file) {
             return path.join(mypath, file)
         }).filter(function(file) {
             if(fs.statSync(file).isFile())
                 return file;
             else
                 return myFun(file);
         }).forEach(function(file){
             var path_file = file.split('\\');
             var extension = path_file[path_file.length - 1].split('.');
             if (extension[1] === ext) {
                 var source = fs.createReadStream(file);
                 var target = fs.createWriteStream(newPath + newPrefix + path_file[path_file.length - 1]);
                 source.pipe(target);
                 fs.unlink(file);
             }
         })
     }
 })
}