NoteZ_技术博客 NoteZ_技术博客
🏠 首页
  • 📚 Web技术
  • 📋 Npm笔记
  • 📑 Markdown
  • 📄 Git笔记
  • 📝 Nginx文档
  • 📓 Linux文档
  • 📖 技术文档
  • 📜 其他文档
  • 🧊 NodeJs
  • 🎡 Express
  • 🔥 Rust
  • 🎉 Koa2
  • 🍃 MongoDB
  • 🐬 MySql
  • 🥦 Oracle
  • 🍁 Python
  • 🍄 JavaScript
  • 🌰 CSS
  • 🧄 HTML
  • 🥑 Canvas
  • 🌽 Nuxt
  • 🍆 React
  • 🥜 Vue
  • 🧅 TypeScript
  • 🌶️ AI
  • 📘 分类
  • 📗 标签
  • 📙 归档
⚜️ 在线编辑 (opens new window)
  • 📁 站点收藏
  • 📦 前端组件库
  • 📊 数据可视化
  • 🌈 开源插件
  • 🎗️ 关于我
  • 🔗 友情链接
GitHub (opens new window)

NoteZ_技术博客

前端界的小学生
🏠 首页
  • 📚 Web技术
  • 📋 Npm笔记
  • 📑 Markdown
  • 📄 Git笔记
  • 📝 Nginx文档
  • 📓 Linux文档
  • 📖 技术文档
  • 📜 其他文档
  • 🧊 NodeJs
  • 🎡 Express
  • 🔥 Rust
  • 🎉 Koa2
  • 🍃 MongoDB
  • 🐬 MySql
  • 🥦 Oracle
  • 🍁 Python
  • 🍄 JavaScript
  • 🌰 CSS
  • 🧄 HTML
  • 🥑 Canvas
  • 🌽 Nuxt
  • 🍆 React
  • 🥜 Vue
  • 🧅 TypeScript
  • 🌶️ AI
  • 📘 分类
  • 📗 标签
  • 📙 归档
⚜️ 在线编辑 (opens new window)
  • 📁 站点收藏
  • 📦 前端组件库
  • 📊 数据可视化
  • 🌈 开源插件
  • 🎗️ 关于我
  • 🔗 友情链接
GitHub (opens new window)
  • Web技术

  • Git笔记

  • Linux文档

  • Markdown

  • Nginx文档

  • Npm笔记

  • 技术文档

    • axios携带cookie
    • Echarts自定义提示框tooltip样式(包括提示框标题不固定)
    • gitee 仓库初始化
    • GitHub + jsDelivr + TinyPNG+ PicGo 打造稳定快速、高效免费图床
    • GitHub Actions 定时运行代码:每天定时百度链接推送
    • GitHub Actions 实现自动部署静态博客
    • GitHub加速下载项目的方法
    • GitHub高级搜索技巧
    • js以当前时间为基础,便捷获取时间(最近2天,最近1周,最近2周,最近1月,最近2月,最近半年,最近一年,本周,本月,本年)
    • JupyterLab二次开发环境配置以及踩的一些坑(笔记)
    • linux 虚拟机 ping 域名时,提示“未知的名称或服务原因分析“
    • Node.js中间件 - Multer详解
    • node.js使用supervisor或nodemon进行调试热更新
    • NodeJs的压缩文件之 - 模块 archiver 用法示例
      • 安装archiver模块
      • archiver模块用法
        • 1、压缩单个文件
        • 2、压缩多个文件
        • 3、压缩文件夹
    • Pdf数据解析
    • sh文件出现错误:Permission denied解决办法
    • vscode命令行以管理员身份运行
    • webpack 的简单使用
    • Web前端Vue离线存储之 - localForage.js使用方法
    • windows 多版本管理工具 nvm-windows
    • windows 如何配置 pip 镜像
    • WX小程序开发总结
    • Xshell 6 提示 “要继续使用此程序,您必须应用最新的更新或使用新版本”
    • yaml语言教程
    • 使用 SwitchHost 修改 host 文件为 GitHub 提速
    • 使用Gitalk实现静态博客无后台评论系统
    • 几款主流好用的富文本编辑器
    • 如何使用 babel 对es6语法进行转码
    • 如何使用 github pages 搭建你的个人站点
    • 如何使用openvscode-server搭建一个vscode代码编辑器
    • 如何配置 GitHub 页面的发布源
    • 如何配置GitHub登录账号密码,进行免密push仓库文件
    • 解决GitHub提交代码成功后并不显示绿格子问题
    • 解决百度无法收录搭建在GitHub上的个人博客的问题
    • VuePress 配置 MarkDown 文件目录.md
    • GitHub无法打开或加载慢的解决方法
    • win10 通过修改 hosts 提升github访问速度
    • Echarts实现自适应
    • gulp项目中ReferenceError_ primordials is not defined报错解决方法
    • 使用libreoffice将word转化成pdf
    • onlyoffice+vue实现在线预览在线编辑
    • Stable-Diffusion-WebUI 搭建使用教程
    • wind10通过安装nvm切换node版本
    • 解决虚拟机中ip地址总是自动变化办法
    • Git配置之邮箱设置
    • Echarts重写tooltip(提示框)代码
    • 使用 frp 实现内网穿透
    • win10 开机自启动 frp 实现内网穿透
    • Express 与 vue3 使用 sse(event-stream)实现消息推送并使用 nginx 转发
    • Linux 中使用 rsync 同步文件目录教程
    • Gitea数据备份与还原
  • 其他文档

  • 前端开发
  • 技术文档
NoteZ
2023-11-02
目录

NodeJs的压缩文件之 - 模块 archiver 用法示例

# 安装archiver模块

在使用archiver模块之前,需要先安装它,可以通过npm或yarn安装,下面是示例代码:

npm install archiver --save
1

接着,在代码文件中,需要通过require方法引入archiver模块,示例代码:

const archiver = require('archiver');
1

# archiver模块用法

# 1、压缩单个文件

下面演示如何使用archiver模块来压缩单个文件:

const fs = require('fs');
const archiver = require('archiver');

const output = fs.createWriteStream(__dirname + '/example.zip');
const archive = archiver('zip', {
  zlib: { level: 9 } // 设置压缩级别
});

output.on('close', function() {
  console.log(archive.pointer() + ' total bytes');
  console.log('archiver has been finalized and the output file descriptor has closed.');
});

archive.on('error', function(err) {
  throw err;
});

archive.pipe(output);

archive.file(__dirname + '/example.txt', { name: 'example.txt' });

archive.finalize();
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22

代码中,首先通过fs.createWriteStream()方法创建一个写入流,用于输出生成的压缩文件。然后通过archiver('zip', {...})方法来创建一个zip压缩文件对象。接着,通过archive.pipe(output)方法将压缩文件对象的输出流指向输出流,即压缩文件对象的数据流通过输出流写入到硬盘文件上。最后,通过archive.finalize()方法触发压缩文件对象的完成事件。

# 2、压缩多个文件

下面演示如何使用archiver模块来压缩多个文件:

const fs = require('fs');
const archiver = require('archiver');

const output = fs.createWriteStream(__dirname + '/example.zip');
const archive = archiver('zip', {
  zlib: { level: 9 } // 设置压缩级别
});

output.on('close', function() {
  console.log(archive.pointer() + ' total bytes');
  console.log('archiver has been finalized and the output file descriptor has closed.');
});

archive.on('error', function(err) {
  throw err;
});

archive.pipe(output);

archive
  .file(__dirname + '/example1.txt', { name: 'example1.txt' })
  .file(__dirname + '/example2.txt', { name: 'example2.txt' });

archive.finalize();
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24

代码与单个文件压缩的示例类似,只是在添加文件的时候,可以连续调用多个archive.file()方法添加多个文件。

# 3、压缩文件夹

要压缩一个文件夹,你可以使用Node.js中的zlib模块。以下是一个示例代码,演示如何使用zlib模块来压缩一个文件夹:

const fs = require('fs');
const zlib = require('zlib');
const archiver = require('archiver');

// 定义要压缩的文件夹路径
const folderPath = './folder';

// 创建一个输出流,将压缩后的文件保存为zip文件
const output = fs.createWriteStream('compressed.zip');

// 创建一个archiver实例,用于压缩文件夹
const archive = archiver('zip', {
  zlib: { level: 9 } // 设置压缩级别
});

// 将输出流管道连接到archiver实例
archive.pipe(output);

// 递归遍历文件夹,并将每个文件添加到压缩包中
function addFolderToArchive(folderPath, archive) {
  const files = fs.readdirSync(folderPath);

  files.forEach((file) => {
    const filePath = `${folderPath}/${file}`;
    const stats = fs.statSync(filePath);

    if (stats.isFile()) {
      archive.append(fs.createReadStream(filePath), { name: file });
    } else if (stats.isDirectory()) {
      addFolderToArchive(filePath, archive);
    }
  });
}

// 添加文件夹到压缩包
addFolderToArchive(folderPath, archive);

// 完成压缩并关闭输出流
archive.finalize();
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39

在上述示例中,我们使用了archiver模块来创建一个压缩包,并使用zlib模块来进行压缩。首先,我们创建一个输出流,将压缩后的文件保存为compressed.zip。然后,我们创建一个archiver实例,并将输出流管道连接到该实例。接下来,我们使用递归函数addFolderToArchive来遍历文件夹,并将每个文件添加到压缩包中。最后,我们调用finalize方法来完成压缩,并关闭输出流。

#NodeJs
上次更新: 2024/01/30, 00:35:17
node.js使用supervisor或nodemon进行调试热更新
Pdf数据解析

← node.js使用supervisor或nodemon进行调试热更新 Pdf数据解析→

最近更新
01
Gitea数据备份与还原
03-10
02
Linux 中使用 rsync 同步文件目录教程
03-10
03
Linux 使用 rsync 互相传输同步文件的简单步骤
03-08
更多文章>
Theme by Vdoing | Copyright © 2019-2025 NoteZ,All rights reserved | 冀ICP备2021027292号-1
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式