首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >nodejs空文档fs.writeFile/appendFile

nodejs空文档fs.writeFile/appendFile
EN

Stack Overflow用户
提问于 2015-08-23 10:29:07
回答 2查看 1.5K关注 0票数 1

我是用nodejs编写聊天日志机器人的新手。现在它运行得很好。除了几个小时后。机器人为每个用户创建一个文档,如果用户还不存在这样的文档,则机器人会输入一些内容,如果存在,则会将其放入该文件中。下面是我的代码:

代码语言:javascript
复制
fs.open('logs/' + channel.substr(1) + '/' + user.username +'.txt','r',function(err,fd){
    if (err && err.code=='ENOENT') 
    {
    fs.writeFile('logs/' + channel.substr(1) + '/' + user.username +'.txt', '[' + 'GMT' + moment().format('Z ') + moment().format('D.M.YYYY H:mm:ss')  + '] ' + user.username + ': ' + message + '\n', function (err) {});
    } else {
    fs.appendFile('logs/' + channel.substr(1) + '/' + user.username +'.txt', '[' + 'GMT' + moment().format('Z ') + moment().format('D.M.YYYY H:mm:ss')  + '] ' + user.username + ': ' + message + '\n', function(){});    
    }
  });

问题是,在用户聊天几个小时后,新用户的文档最终都是空的。保持聊天的较老的聊天人员也不会在其文件中添加新行。

我使用"graceful-fs“模块是因为我希望它能解决这个问题,但我不认为这个模块有太多变化。我做错了什么?为什么我的新.txt文件以空结尾(0 kb大小)

EN

回答 2

Stack Overflow用户

发布于 2015-08-23 10:40:55

打开文件描述符时,必须最终将其关闭(fs.close)。每次运行这段代码时,都会泄漏一个文件描述符。根据您的操作系统和设置,每个进程都被限制为一定数量的文件描述符。用完后,需要打开文件的任何操作都不会成功。

票数 2
EN

Stack Overflow用户

发布于 2015-08-23 10:39:40

你可以直接使用

代码语言:javascript
复制
fs.appendFile(filename, data, {flag: "a+"}, callback)

如果文件存在,这将附加到该文件,否则将使用给定的数据创建该文件。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/32162613

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档