nodejs模块fs——文件操作api

本文详细介绍了Node.js中fs模块的使用方法,包括文件的读取、写入、追加、拷贝及删除等基本操作,并对文件夹的创建、读取及删除进行了讲解。
// fs模块常用api

//  读取文件 、写入文件 、追加文件、 拷贝文件 、删除文件

//  读取文件
//  fs.readFile(path[, options], callback)
//  fs.readFileSync(path[, options])

const fs = require('fs')
//  异步读取
fs.readFile('./test.json', (error, data) => {
    if (error) return
    var data = data.toString()
    console.log(data)
})
//  同步读取
try {
    let data = fs.readFileSync('./test.json','utf-8')
    console.log(data)
} catch (error) {
    console.log(error)
}

//  文件写入
//  fs.writeFile(file, data[, options], callback)
//  fs.writeFileSync(file, data[, options])

//  异步写入
fs.writeFile('./data/datalist.json','{"data":"测试数据"}', error => {
        if (error) {
            console.log(error)
        }
    })
//  同步写入
try {
    fs.writeFileSync('./data/datalist.json','{"data":"测试数据2"}')
} catch (error) {
    console.log(error)
}

//  文件追加
//  fs.appendFile(path, data[, options], callback)
//  fs.appendFileSync(path, data[, options], callback)

//  异步追加
fs.appendFile('./data/datalist.json','追加数据',err=>{
   if(err) console.log(err)
})
// //  同步追加
try {
    fs.appendFileSync('./data/datalist.json','同步追加')
} catch (error) {
    console.log(error);
}

//  文件拷贝
//  fs.copyFile(src, dest[, flags], callback)
//  fs.copyFileSync(src, dest[, flags], callback)

//  异步拷贝
fs.copyFile('./test.json','test_copy_async.json',err=>{
    if(err) console.log(err);
})
// //  同步拷贝
try {
    fs.copyFileSync('./test.json','test_copy_sync.json')
} catch (error) {
    
}

//  文件删除
//  fs.unlink(path, callback)
//  fs.unlinkSync(path, callback)

//  异步删除
fs.unlink('./test_copy_async.json',err=>{
    if(err)console.log(err)
})
// //  同步删除
try {
    fs.unlinkSync('./test_copy_sync.json')
} catch (error) {
    console.log(error)
}

// 总结 :

// 同步都是在原api后面添加“Sync”,参数类似(path[, options], callback)
// 文件读取:readFile
// 文件写入:writeFile
// 文件追加:appendFile
// 文件拷贝:copyFile
// 文件删除:unlink

 文件夹相关api

//文件夹操作常用api
const fs = require('fs')

//  创建文件夹
//  fs.mkdir(path[, options], callback)
//  fs.mkdirSync(path[, options])

fs.mkdir('./static/js',{ recursive: true },err=>{
    //  recursive: true  创建/static/css目录,无论是否存在 /static 目录。
    if(err)console.log(err);
})

//  读取文件夹
fs.readdir('./static',{withFileTypes:false},(err,data)=>{
    if(err){
        console.log(err)
        return
    }
    console.log(data);
    // {withFileTypes:false},返回字符串组成的数组
    //  [ 'aaa.text', 'css', 'images', 'js' ]

    // {withFileTypes:true},返回dirent对象组成的数组
        // dirent.isFile() 判断是否是常规文件
        // dirent.isDirectory() 判断是否是文件目录
    // [ 
    //     Dirent { name: 'aaa.text', [Symbol(type)]: 1 },
    //     Dirent { name: 'css', [Symbol(type)]: 2 },
    //     Dirent { name: 'images', [Symbol(type)]: 2 },
    //     Dirent { name: 'js', [Symbol(type)]: 2 } 
    // ]
})

// 删除文件
// fs.rmdir(path, callback)
// fs.rmdirSync(path, callback)
// ps:添加options{recursive:true},报错
fs.rmdir('./static/images',err=>{
    if(err) console.log(err)
})

 

转载于:https://www.cnblogs.com/superjsman/p/11606974.html

Nano-ESG数据资源库的构建基于2023年初至2024年秋季期间采集的逾84万条新闻文本,从中系统提炼出企业环境、社会及治理维度的信息。其构建流程首先依据特定术语在德语与英语新闻平台上检索,初步锁定与德国DAX 40成分股企业相关联的报道。随后借助嵌入技术对文本段落执行去重操作,以降低内容冗余。继而采用GLiNER这一跨语言零样本实体识别系统,排除与目标企业无关的文档。在此基础上,通过GPT-3.5与GPT-4o等大规模语言模型对文本进行双重筛选:一方面判定其与ESG议题的相关性,另一方面生成简明的内容概要。最终环节由GPT-4o模型完成,它对每篇文献进行ESG情感倾向(正面、中性或负面)的判定,并标注所涉及的ESG具体维度,从而形成具备时序特征的ESG情感与维度标注数据集。 该数据集适用于多类企业可持续性研究,例如ESG情感趋势分析、ESG维度细分类别研究,以及企业可持续性事件的时序演变追踪。研究者可利用数据集内提供的新闻摘要、情感标签与维度分类,深入考察企业在不同时期的环境、社会及治理表现。此外,借助Bertopic等主题建模方法,能够从数据中识别出与企业相关的核心ESG议题,并观察这些议题随时间的演进轨迹。该资源以其开放获取特性与连续的时间覆盖,为探究企业可持续性表现的动态变化提供了系统化的数据基础。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值