在Node.js中实现文件复制的方法和实例_node.js
流
流是 Node.js 移动数据的方式,Node.js 中的流是可读/可写的,HTTP 和文件系统模块都有用到流。在文件系统中,使用流来读取文件的时候,对于一个大文件可能并不会一次性读取完,而是会分好几次读取完,读取的时候会响应数据事件,在文件没读取完的时候就可以对读取的数据进行操作。同理,在写入流的时候也和读取时一样,大文件并不会一次性写入。这种移动数据的方式是非常高效的,尤其是对于大文件而言,使用流比等待将大文件全部读取完再来操作文件要快得多。
管道
如果想在读取流和写入流的时候做完全的控制,可以使用数据事件。但对于单纯的文件复制来说读取流和写入流可以通过管道来传输数据。
实际应用:
var fs = require( 'fs' ),
stat = fs.stat;
/*
* 复制目录中的所有文件包括子目录
* @param{ String } 需要复制的目录
* @param{ String } 复制到指定的目录
*/
var copy = function( src, dst ){
// 读取目录中的所有文件/目录
fs.readdir( src, function( err, paths ){
if( err ){
throw err;
}
paths.forEach(function( path ){
var _src = src + '/' + path,
_dst = dst + '/' + path,
readable, writable;
stat( _src, function( err, st ){
if( err ){
throw err;
}
// 判断是否为文件
if( st.isFile() ){
// 创建读取流
readable = fs.createReadStream( _src );
// 创建写入流
writable = fs.createWriteStream( _dst );
// 通过管道来传输流
readable.pipe( writable );
}
// 如果是目录则递归调用自身
else if( st.isDirectory() ){
exists( _src, _dst, copy );
}
});
});
});
};
// 在复制目录前需要判断该目录是否存在,不存在需要先创建目录
var exists = function( src, dst, callback ){
fs.exists( dst, function( exists ){
// 已存在
if( exists ){
callback( src, dst );
}
// 不存在
else{
fs.mkdir( dst, function(){
callback( src, dst );
});
}
});
};
// 复制目录
exists( './src', './build', copy );
推荐阅读
-
node.js中fs文件系统模块的使用方法实例详解
-
node.js中stream流中可读流和可写流的实现与使用方法实例分析
-
在VB中遍历文件并用正则表达式完成复制及vb实现重命名、拷贝文件夹的方法
-
使用Node.js实现base64和png文件相互转换的方法
-
使用console.dir 快速概览Node.JS中对象实例的属性和方法
-
在Node.js中实现文件复制的方法和实例_node.js
-
node.js中stream流中可读流和可写流的实现与使用方法实例分析
-
node.js中fs文件系统模块的使用方法实例详解
-
Nodejs中调用系统命令、Shell脚本和Python脚本的方法和实例_node.js
-
在Node.js中实现文件复制的方法和实例_node.js