node快速复制文件或文件夹,排除部分文件(node_modules)

2024-09-08 03:20

本文主要是介绍node快速复制文件或文件夹,排除部分文件(node_modules),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述


const fs = require('fs')
const path = require('path')/*** @description: 获取完整的文件路径* @param {*} url 路径* @return {*} 返回完整的文件路径*/
const getPath = (url) => {return path.join(__dirname, url)
}/*** @description: 获取参数* @return {*} target【目标文件夹】 source【源文件夹】*/
function parseArgv() {let arguments = process.argv.splice(2)const target = arguments[0] || './copy'const source = arguments[1] || './'return { target, source }
}/*** @description: 是否是文件夹* @param {*} pathDir 路径* @return {*} true 是,false 否*/
const isDir = (pathDir) => {const path = getPath(pathDir)let data = falsetry {data = fs.statSync(path).isDirectory()return data} catch (error) {return data}
}/*** @description: 获取文件夹列表* @param {*} pathDir 路径* @return {*} 文件列表*/
const getDirList = (pathDir) => {const path = getPath(pathDir)return new Promise((resolve, reject) => {fs.readdir(path, (err, data) => {if (err) {rejects(err)}resolve(data)})})
}const exclude = ['node_modules', '.gitignore']const main = async (target, source) => {let list = await getDirList(source)const except = [path.basename(target), path.parse(__filename).base]list = list.filter((item) => {return !except.includes(item)})isDir(target) ? '' : fs.mkdirSync(target, { recursive: true })const copyFile = (list, target, source) => {const result = list.filter((item) => {return !exclude.includes(item)})result.forEach(async (item) => {const path =source.endsWith('./') || source.endsWith('/')? './' + item: source + '/' + item // 原始路径const copyPath = target + '/' + item //复制的路径if (isDir(path)) {if (!fs.existsSync(copyPath)) {await fs.mkdirSync(copyPath)console.log(`正在复制:文件夹从${getPath(path)}------->复制到${getPath(copyPath)} ======成功`)}let needCopyList = await getDirList(path)await copyFile(needCopyList, copyPath, path)} else {if (!fs.existsSync(copyPath)) {fs.copyFileSync(path, copyPath)console.log(`正在复制:文件从${getPath(path)}------->复制到${getPath(copyPath)} ======成功`)}}})}copyFile(list, target, source)
}
const { target, source } = parseArgv()
main(target, source)

这篇关于node快速复制文件或文件夹,排除部分文件(node_modules)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1146973

相关文章

一文详解如何在Python中从字符串中提取部分内容

《一文详解如何在Python中从字符串中提取部分内容》:本文主要介绍如何在Python中从字符串中提取部分内容的相关资料,包括使用正则表达式、Pyparsing库、AST(抽象语法树)、字符串操作... 目录前言解决方案方法一:使用正则表达式方法二:使用 Pyparsing方法三:使用 AST方法四:使用字

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

使用Node.js制作图片上传服务的详细教程

《使用Node.js制作图片上传服务的详细教程》在现代Web应用开发中,图片上传是一项常见且重要的功能,借助Node.js强大的生态系统,我们可以轻松搭建高效的图片上传服务,本文将深入探讨如何使用No... 目录准备工作搭建 Express 服务器配置 multer 进行图片上传处理图片上传请求完整代码示例

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

springboot security快速使用示例详解

《springbootsecurity快速使用示例详解》:本文主要介绍springbootsecurity快速使用示例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录创www.chinasem.cn建spring boot项目生成脚手架配置依赖接口示例代码项目结构启用s

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

一文教你Python引入其他文件夹下的.py文件

《一文教你Python引入其他文件夹下的.py文件》这篇文章主要为大家详细介绍了如何在Python中引入其他文件夹里的.py文件,并探讨几种常见的实现方式,有需要的小伙伴可以根据需求进行选择... 目录1. 使用sys.path动态添加路径2. 使用相对导入(适用于包结构)3. 使用pythonPATH环境

nvm如何切换与管理node版本

《nvm如何切换与管理node版本》:本文主要介绍nvm如何切换与管理node版本问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录nvm切换与管理node版本nvm安装nvm常用命令总结nvm切换与管理node版本nvm适用于多项目同时开发,然后项目适配no

C++快速排序超详细讲解

《C++快速排序超详细讲解》快速排序是一种高效的排序算法,通过分治法将数组划分为两部分,递归排序,直到整个数组有序,通过代码解析和示例,详细解释了快速排序的工作原理和实现过程,需要的朋友可以参考下... 目录一、快速排序原理二、快速排序标准代码三、代码解析四、使用while循环的快速排序1.代码代码1.由快