array(2) { ["docs"]=> array(10) { [0]=> array(10) { ["id"]=> string(3) "428" ["text"]=> string(77) "Visual Studio 2017 单独启动MSDN帮助(Microsoft Help Viewer)的方法" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(8) "DonetRen" ["tagsname"]=> string(55) "Visual Studio 2017|MSDN帮助|C#程序|.NET|Help Viewer" ["tagsid"]=> string(23) "[401,402,403,"300",404]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511400964" ["_id"]=> string(3) "428" } [1]=> array(10) { ["id"]=> string(3) "427" ["text"]=> string(42) "npm -v;报错 cannot find module "wrapp"" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(4) "zzty" ["tagsname"]=> string(50) "node.js|npm|cannot find module "wrapp“|node" ["tagsid"]=> string(19) "[398,"239",399,400]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511400760" ["_id"]=> string(3) "427" } [2]=> array(10) { ["id"]=> string(3) "426" ["text"]=> string(54) "说说css中pt、px、em、rem都扮演了什么角色" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(12) "zhengqiaoyin" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511400640" ["_id"]=> string(3) "426" } [3]=> array(10) { ["id"]=> string(3) "425" ["text"]=> string(83) "深入学习JS执行--创建执行上下文(变量对象,作用域链,this)" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(7) "Ry-yuan" ["tagsname"]=> string(33) "Javascript|Javascript执行过程" ["tagsid"]=> string(13) "["169","191"]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511399901" ["_id"]=> string(3) "425" } [4]=> array(10) { ["id"]=> string(3) "424" ["text"]=> string(30) "C# 排序技术研究与对比" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(9) "vveiliang" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(8) ".Net Dev" ["catesid"]=> string(5) "[199]" ["createtime"]=> string(10) "1511399150" ["_id"]=> string(3) "424" } [5]=> array(10) { ["id"]=> string(3) "423" ["text"]=> string(72) "【算法】小白的算法笔记:快速排序算法的编码和优化" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(9) "penghuwan" ["tagsname"]=> string(6) "算法" ["tagsid"]=> string(7) "["344"]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511398109" ["_id"]=> string(3) "423" } [6]=> array(10) { ["id"]=> string(3) "422" ["text"]=> string(64) "JavaScript数据可视化编程学习(二)Flotr2,雷达图" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(7) "chengxs" ["tagsname"]=> string(28) "数据可视化|前端学习" ["tagsid"]=> string(9) "[396,397]" ["catesname"]=> string(18) "前端基本知识" ["catesid"]=> string(5) "[198]" ["createtime"]=> string(10) "1511397800" ["_id"]=> string(3) "422" } [7]=> array(10) { ["id"]=> string(3) "421" ["text"]=> string(36) "C#表达式目录树(Expression)" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(4) "wwym" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(4) ".NET" ["catesid"]=> string(7) "["119"]" ["createtime"]=> string(10) "1511397474" ["_id"]=> string(3) "421" } [8]=> array(10) { ["id"]=> string(3) "420" ["text"]=> string(47) "数据结构 队列_队列实例:事件处理" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(7) "idreamo" ["tagsname"]=> string(40) "C语言|数据结构|队列|事件处理" ["tagsid"]=> string(23) "["246","247","248",395]" ["catesname"]=> string(12) "数据结构" ["catesid"]=> string(7) "["133"]" ["createtime"]=> string(10) "1511397279" ["_id"]=> string(3) "420" } [9]=> array(10) { ["id"]=> string(3) "419" ["text"]=> string(47) "久等了,博客园官方Android客户端发布" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(3) "cmt" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511396549" ["_id"]=> string(3) "419" } } ["count"]=> int(200) } 222 node fs模块--文件操作 - 爱码网
1、异步读取
  fs.readFile( url , code , callback);
 
2、同步读取
  fs.readFileSync( url , code );
  
 1 var fs = require('fs');
 2 // 异步读取
 3 fs.readFile('input.txt', function (err, data) {
 4     if (err)    return console.log(err);
 5     console.log('异步读取:' + data.toString());
 6 })
 7 // 同步读取
 8 var data = fs.readFileSync('input.txt');
 9 console.log('同步读取:' + data.toString());
10 console.log('程序执行完毕。');
 
3、改变文件名
  fs.rename(old文件名,新文件名,callback(传递一个err参数))
 
4、同步改变文件名
  fs.renameSync(oldPath, newPath) 
  
1 fs.rename('hello.txt','index.txt',function(){
2      console.log("修改成功");
3 });

 

5、获取文件信息
  fs.start(path, callback) 参数使用说明如下:
    path - 文件路径。 callback - 回调函数,带有两个参数如:(err, stats), stats 是 fs.Stats 对象
 1     
 2 fs.stat('index.txt',function(err,stats){
 3   if(err){
 4     return err;
 5   }
 6   console.log(stats);
 7   console.log("读取文件信息成功");
 8   //检测文件类型
 9   console.log('是否为文件(isFile) ? ' + stats.isFile());
10   console.log('是否为目录(isDirectory) ? ' + stats.isDirectory());
11 });

6、打开文件

  fs.open(path, flags[, mode], callback)
  参数使用说明如下:
    path - 文件的路径。
    flags - 文件打开的行为。
    mode - 设置文件模式(权限),文件创建默认权限为 0666(可读,可写)。
    callback - 回调函数,带有两个参数如:callback(err, fd)。
 
1 fs.open('index.txt','r+',function(err,fd){
2     if(err) return err;
3     console.log(fd);
4     console.log('文件打开成功');
5 
6 });

 

7、写入文件

  fs.writeFile(filename, data[, options], callback)

  如果文件存在,写入的内容会覆盖旧文件内容
    参数使用说明如下:
      path - 文件路径。
      data - 要写入文件的数据,可以是 String(字符串) 或 Buffer(流) 对象。
      options - 该参数是一个对象,包含 {encoding, mode, flag}。默认编码为 utf8, 模式为 0666 ,flag 为 'w'
      callback - 回调函数,回调函数只包含错误信息参数(err),在写入失败时返回。
 1 var fs = require('fs');
 2 console.log('准备写入文件');
 3 fs.writeFile('input.txt', '我是新写入的内容', function (err) {
 4     if (err) console.error(err);
 5     console.log('数据写入的数据');
 6     console.log('-------------------');
 7 });
 8 console.log('读取写入的数据');
 9 fs.readFile('input.txt', function (err, data) {
10     if (err) console.error(err);
11     console.log('异步读取文件数据:' + data.toString());
12 })

 

8、读入文件

  

  fs.writeFile(filename, data[, options], callback)

    如果文件存在,写入的内容会覆盖旧文件内容
      参数使用说明如下:
        path - 文件路径。
        data - 要写入文件的数据,可以是 String(字符串) 或 Buffer(流) 对象。
        options - 该参数是一个对象,包含 {encoding, mode, flag}。默认编码为 utf8, 模式为 0666 ,flag 为 'w'
        callback - 回调函数,回调函数只包含错误信息参数(err),在写入失败时返回。
 1 var fs = require('fs');
 2 var buf = new Buffer(1024);
 3 fs.open('input.txt', 'r+', function (err, fd) {
 4     if (err) return console.error(err);
 5     console.log('文件打开成功');
 6     console.log('准备读取文件');
 7     // fd fs.open的标识
 8     // buf 缓存区
 9     // 0, buf.length 缓存区区间
10     // 0, 读取input.txt开始位置
11     fs.read(fd, buf, 0, buf.length, 0, function (err, bytes) {
12         if (err) console.log(err);
13         console.log(bytes + ' 字节被读取');
14 
15         if (bytes > 0) {
16             console.log(buf.slice(0, bytes).toString());
17         }
18     })
19 })

 

9、关闭文件

  fs.close(fd, callback)

    参数使用说明如下:

      fd - 通过 fs.open() 方法返回的文件描述符。

      callback - 回调函数,没有参数。

 1 var fs = require('fs');
 2 var buf = new Buffer(1024);
 3 fs.open('input.txt', 'r+', function (err, fd) {
 4     if (err) return console.error(err);
 5     console.log('文件打开成功');
 6     console.log('准备读取文件');
 7     // fd fs.open的标识
 8     // buf 缓存区
 9     // 0, buf.length 缓存区区间
10     // 0, 读取input.txt开始位置
11     fs.read(fd, buf, 0, buf.length, 0, function (err, bytes) {
12         if (err) console.log(err);
13         console.log(bytes + ' 字节被读取');
14 
15         if (bytes > 0) {
16             console.log(buf.slice(0, bytes).toString());
17         }
18     })
19     // 关闭文件 
20     fs.close(fd, function (err){
21         if (err) console.error(err);
22         console.log('文件关闭成功');
23     });
24 })

 

10、截取文件

  fs.ftruncate(fd, len, callback)

    该方法使用了文件描述符来读取文件 参数

       fd - 通过 fs.open() 方法返回的文件描述符。

       len - 文件内容截取的长度。 callback - 回调函数,没有参数

 1 var fs = require('fs');
 2 var buf = new Buffer(1024);
 3 console.log('准备打开文件');
 4 fs.open('input.txt', 'r+', function (err, fd) {
 5     if (err) return console.error(err);
 6     console.log('文件打开成功');
 7     console.log('截取10字节后的文件内容');
 8     // 截取文件
 9     fs.ftruncate(fd, 10, function (err) {
10         if (err) console.log(err);
11         console.log('文件截取成功');
12         console.log('读取相同的文件');
13         fs.read(fd, buf, 0, buf.length, 0, function (err, bytes) {
14             if (err) console.error(err);
15             // 仅仅输出读取的字节
16             if (bytes > 0) {
17                 console.log(buf.slice(0, bytes).toString());
18             }
19             // 关闭文件
20             fs.close(fd, function (err) {
21                 if (err) console.error(err);
22                 console.log('文件关闭成功');
23             })
24         })
25     })
26 })

 

11、删除文件

  fs.unlink(path, callback)

    参数

      path - 文件路径

      callback - 回调函数,无参

1 var fs = require('fs');
2 console.log('准备删除文件');
3 fs.unlink('input.txt', function (err) {
4     if (err) return console.log(err);
5     console.log('文件删除成功');
6 })

 

12、创建目录

  fs.mkdir(path[, mode], callback)

    参数

       path - 文件路径

      mode - 设置目录权限,默认为0777 callback - 回调函数

1 var fs = require('fs');
2 console.log('创建目录 test');
3 fs.mkdir('test', function (err) {
4     if (err) return console.error(err);
5     console.log('目录创建成功');
6 });

 

13、查看目录

  fs.readdir(path, callback)

    参数使用说明如下:

       path - 文件路径。

       callback - 回调函数,回调函数带有两个参数err, files,err 为错误信息,files 为 目录下的文件数组列表

1 var fs = require('fs');
2 console.log('查看 /file 目录');
3 fs.readdir('../file/', function (err, files) {
4     if (err) return console.log(err);
5     files.forEach(function (file) {
6         console.log(file);
7     })
8 })

 

14、删除目录

   fs.rmdir(path, callback)
     参数使用说明如下:
       path - 文件路径。
      callback - 回调函数,没有参数。
 1 var fs = require('fs');
 2 console.log('删除 /test 目录');
 3 fs.rmdir('test', function (err){
 4     if (err) console.error(err);
 5     console.log('读取 /test 目录');
 6     fs.readdir('test', function (err, files) {
 7         if (err) return console.log(err);
 8         files.forEach(function (file) {
 9             console.log(file);
10         })
11     })
12 });

 

 15、判断文件路径是否存在
  fs.exists(path, callback)
    接收参数:

      path 欲检测的文件路径

      callback 回调

1 fs.exists('/chengyi',function(exists){
2     if(exists){
3         console.log('路径存在');
4     }
5 });

 

16、向文件中追加写入

  fs.appendFile(name,str,encode,callback);

    参数

      name : 文件名

      str : 添加的字段

      encode : 设置编码

      callback : 回调函数

  

1     fs.appendFile('index.txt','窗前明月光,疑是地上霜','utf8',function(err){
2         if(err) console.log(err);
3         fs.readFile('index.txt','utf8',function(err,data){
4             if(err) console.log(err);
5             console.log(data);
6         });
7     });

 

 

相关文章: