nodejs-检查目录文件是否存在

本文介绍如何使用Node.js的fs模块来检查文件是否存在,并获取指定目录下的文件数量及每个文件的绝对路径。针对异步操作导致的问题,文章还提供了一种同步解决方案。

fs.exists(path,callback)来检查目录文件是否存在,

var fs=require("fs");
fs.exists("../7",function(exists){
  if(exists){
     console.log("文件存在")
  }
     if(!exists){
        console.log("文件不存在")
     }
  })


7这个文件夹下有多少个文件,查看每个文件的绝对路径

var fs=require("fs");
var p=require("path");
var path='';
fs.exists("../7",function(exists){
     if(exists){
         fs.readdir('../7',function(err,files){
              if(err){
                 console.log("读取文件夹下7文件失败");
              }else{
                 console.log("7文件夹下有"+files.length+"个文件");
                 for(var i=0;i<files.length;i++){
                     path=p.resolve(__dirname,'../7')+p.sep
                     path=path+files[i];
                     console.log("----"+path)
                     fs.stat(path,function(err,stat){
                        if(err){
                            console.log("查看文件夹7下的文件信息失败");
                        }else{
                            if(stat.isFile()){
                                fs.realpath(path,function(err,resolvePath){
                                    if(err){
                                        throw err;
                                      //console.log("查看文件绝对路径失败");
                                    }else{
                                       console.log("文件的路径为"+resolvePath)
                                    }
                                     
                                })
                                
                            }
                        }
                     })
                 }
              }
         })
     }
     if(!exists){
        console.log("文件不存在")
     }
  })

得到的结果为下图,我们发现得到的绝对路径有问题,原因是回调函数还没有反回来呢,你的for循环又开始往下执行了,吧这个文件path更改了。改成同步试一下


var fs=require("fs");
var p=require("path");
var path='';
fs.exists("../7",function(exists){
     if(exists){
         fs.readdir('../7',function(err,files){
              if(err){
                 console.log("读取文件夹下7文件失败");
              }else{
                 console.log("7文件夹下有"+files.length+"个文件");
                 for(var i=0;i<files.length;i++){
                     path=p.resolve(__dirname,'../7')+p.sep
                     path=path+files[i];
                     console.log("----"+path)
                   

                    var stat=fs.statSync(path);
                    if(stat.isFile()){
                        var resolvePath=fs.realpathSync(path);
                        console.log("文件的路径为"+resolvePath);
                            
                        
                                                     
                    }
                 }
              }
         })
     }
     if(!exists){
        console.log("文件不存在")
     }
  })

运行结果:




### 在 Node.js 爬虫项目中添加文件的方法 在 Node.js 爬虫项目中,添加文件通常涉及将爬取到的数据或资源(如图片、文本等)保存到本地文件系统中。可以通过 `fs` 模块来实现文件的写入操作。以下是具体方法和示例代码: #### 使用 `fs` 模块保存文件 Node.js 内置的 `fs` 模块提供了对文件系统的访问能力。可以使用同步或异步的方式写入文件。为了提高性能和避免阻塞事件循环,推荐使用异步方法。 以下是一个将爬取到的内容保存为文件的示例: ```javascript const fs = require('fs'); const path = require('path'); // 假设这是从网页上爬取到的数据 const scrapedData = '这是从网页上爬取到的数据内容'; // 定义保存文件的路径 const filePath = path.resolve(__dirname, 'scraped_data.txt'); // 异步写入文件 fs.writeFile(filePath, scrapedData, 'utf8', (err) => { if (err) { console.error('写入文件失败:', err); } else { console.log('文件已成功保存:', filePath); } }); ``` 上述代码通过 `fs.writeFile` 方法将爬取到的数据保存为一个文本文件[^1]。 #### 添加文件时的注意事项 1. **确保目录存在**:在写入文件之前,需要确认目标目录是否存在。如果不存在,可以使用 `fs.mkdir` 创建目录。 2. **处理文件编码**:根据数据类型选择合适的编码格式(如 UTF-8)。 3. **错误处理**:始终捕获并处理可能发生的错误,以避免程序崩溃。 #### 示例:创建目录并保存文件 以下代码展示了如何在保存文件检查并创建目录: ```javascript const fs = require('fs'); const path = require('path'); const { promisify } = require('util'); const mkdir = promisify(fs.mkdir); const writeFile = promisify(fs.writeFile); async function saveFile(data, directory, fileName) { const dirPath = path.resolve(__dirname, directory); const filePath = path.resolve(dirPath, fileName); try { // 检查目录是否存在,如果不存在则创建 await mkdir(dirPath, { recursive: true }); // 写入文件 await writeFile(filePath, data, 'utf8'); console.log('文件已成功保存:', filePath); } catch (error) { console.error('保存文件失败:', error); } } // 调用函数 saveFile('这是从网页上爬取到的数据内容', 'output', 'scraped_data.txt'); ``` 此代码片段结合了 `mkdir` 和 `writeFile` 的异步版本,确保目录存在后再写入文件[^5]。 #### 使用第三方库保存文件 除了内置的 `fs` 模块,还可以使用第三方库(如 `fs-extra`)来简化文件操作。`fs-extra` 提供了更丰富的功能,例如递归创建目录等。 安装 `fs-extra`: ```bash npm install fs-extra ``` 使用示例: ```javascript const fse = require('fs-extra'); const path = require('path'); // 定义文件路径 const filePath = path.resolve(__dirname, 'output', 'scraped_data.txt'); // 写入文件 fse.outputFile(filePath, '这是从网页上爬取到的数据内容', 'utf8') .then(() => { console.log('文件已成功保存:', filePath); }) .catch((err) => { console.error('保存文件失败:', err); }); ``` `fs-extra` 的 `outputFile` 方法会自动创建所需的目录结构,简化了文件保存流程[^3]。 --- ### 总结 在 Node.js 爬虫项目中,添加文件的主要方法是通过 `fs` 模块或第三方库(如 `fs-extra`)实现文件的写入操作。确保在写入文件检查并创建必要的目录,并妥善处理可能发生的错误。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值