文件的写入-对Excel文件数据操作-express生成器——

fs.writeFile

异步地将数据写入到一个文件,如果文件已存在则覆盖该文件。 data 可以是字符串或 buffer。

fs.writeFile('a.txt', '文本内容', 'utf8', function(){
});
fs.writeFile(path.join(__dirname,"a.txt"),"ajaksjdlakjdlkasjdalkjsd",function(err){
    console.log(err);
})

封装fs.appendFile

向文件尾部增加新数据,如果该文件不存在就会创建一个新文件

fs.appendFile(path.join(__dirname,"a.txt"),"\nbbbb",function(err){
    console.log(err);
})
function appendFile(data){
    return new Promise((resolve,reject)=>{
        fs.appendFile(path.join(__dirname,"a.txt"),"\n"+data,function(err){
            resolve(!err);
        })
    })
}

fs.rename

异步地把 oldPath 文件重命名为 newPath 提供的路径名。

fs.rename(path.join(__dirname,"a.txt"),path.join(__dirname,"b.txt"),function(err){
    console.log(err);
})

fs.unlink

删除文件

fs.unlink(path.join(__dirname,"b.txt"),function(err){
    console.log(err);
})

监视文件

监视文件的变化

fs.watch(path.join(__dirname,"a.txt"),"utf8",function(event,filename){
    console.log(event,filename);
})

fs.createReadStream()

读取文件流
流式写入,如果是大文件,内容较多,例如视频等就需要流式写入,防止内存卡死


const fs = require('fs')
const readstream = fs.createReadStream('./note.txt');
readstream.pipe(fs.createWriteStream('./note2.txt'));

对.xlsx的文件数据的操作

利用插件来完成对excel表格数据的筛选。

import xlsx from "node-xlsx";
import fsp from "fs/promises";封装好的数据
import path from "path";

init();
async function init(){
     var data=await fsp.readFile(path.join(path.resolve(),"abc.xlsx"));
     data=xlsx.parse(data)[0];
     var arr=data.data.slice(0,4).concat(data.data.slice(4).filter(item=>item[5]>=90));
     var buffer=xlsx.build([{name:"GP27考试90分以上的表格",data:arr}]);
     await fsp.writeFile(path.join(path.resolve(),"90Up.xlsx"),buffer);
}

express基础

全局安装express,引入

var express = require('express');
var app = express();

启动命令:

node app.js

express的通信应用

app.get

app.post

var express=require("express");
var app=express();
app.post("/a",function(req,res){
   //req 这里的req就是请求数据的内容
})
app.listen(4001);

app.put,app.delete,app.all

express中间件和路由

  • 1、GET请求会向数据库发索取数据的请求,从而来获取信息,该请求就像数据库的select操作一样,只是用来查询一下数据,不会修改、增加数据,不会影响资源的内容,即该请求不会产生副作用。无论进行多少次操作,结果都是一样的。
  • 2、与GET不同的是,PUT请求是向服务器端发送数据的,从而改变信息,该请求就像数据库的update操作一样,用来修改数据的内容,但是不会增加数据的种类等,也就是说无论进行多少次PUT操作,其结果并没有不同。
  • 3、POST请求同PUT请求类似,都是向服务器端发送数据的,但是该请求会改变数据的种类等资源,就像数据库的insert操作一样,会创建新的内容。几乎目前所有的提交操作都是用POST请求的。
  • 4、DELETE请求顾名思义,就是用来删除某一个资源的,该请求就像数据库的delete操作。

app.all是不管哪种都可以接收

app.use用于中间件

app.use("/",function(req,res,next){
    res.set({'Access-Control-Allow-Origin':'*'});//例如在这里处理跨域问题
    next();
})

app.set

部分第三方的一些插件在express框架中使用时需要设置一些基础参数,便于在使用时直接调用,这里有一部分是固定属性,也可以自定义属性
例如express框架使用时:

//设置views文件夹也就是模板文件夹,对于调用的路径是view文件夹下
app.set("views",path.join(__dirname,"./view"));
//设置视图解析的方式是通过art这个注册的插件
app.set("view engine","art");
 - use一般用于中间件,目的是在发送之前,或者某件事件之前先做一些处理,例如提前处理一些数据
 - 注意use后面的第二个函数中有3个参数,第一个是req,第二个是res,第三个是next
   我们在use中处理完内容后,必须执行next()这样才可以进入后续的内容,否则将不会向后继续执行

可以通过express 快速生成服务器骨架

下载

npm i express-generator -g

express中提供了 ejs,hbs,pug,hogan.js等引擎,不带art-template 这里我们可以尝试使用ejs完成

express --view=ejs 
或者
express -e

"morgan": "~1.9.1":生成日志的插件
现阶段常用的几个插件:

"devDependencies": {
	"cross-env":"^7.0.3",
	"nodemon":"^2.0.19"
}
"scripts": {
	"start": "cross-env PORT=4000 nodemon ./bin/www"
},

执行 npm i
启动DEBUG=express2:* & npm start
写入文件
writeFile
保存图片
http-server

在这里插入图片描述


相关文章

学习编程是顺着互联网的发展潮流,是一件好事。新手如何学习...
IT行业是什么工作做什么?IT行业的工作有:产品策划类、页面...
女生学Java好就业吗?女生适合学Java编程吗?目前有不少女生...
Can’t connect to local MySQL server through socket \'/v...
oracle基本命令 一、登录操作 1.管理员登录 # 管理员登录 ...
一、背景 因为项目中需要通北京网络,所以需要连vpn,但是服...