当前位置: 首页 > news >正文

uniapp iosApp H5+本地文件操作(写入修改删除等)

h5+ 地址 html5plus

以csv文件为例,写入读取保存修改删除文件内容,传输文件等

1.save 文件保存

function saveCsv(data,pathP,path){// #ifdef APP-PLUSreturn new Promise((resolve, reject) => {plus.io.requestFileSystem( plus.io.PUBLIC_DOCUMENTS, function( fs ) {// 通过fs.root获取DirectoryEntry对象进行操作fs.root.getDirectory(pathP,{create:true},direEntry =>{plus.io.requestFileSystem(plus.io.PUBLIC_DOCUMENTS, fs => {fs.root.getFile(path, {create: true}, fileEntry => {fileEntry.createWriter(writer => {writer.onwrite = e => {resolve(`file://${e.target.fileName}`);// uni.showModal({// 	title: '提示',// 	content: `导出成功,文件路径为${e.target.fileName.replace('/storage/emulated/0', '')}`,// 	cancelText: '了解并关闭',// 	confirmText: '预览文件',// 	success: result => {// 		if (result.confirm) {// 			uni.openDocument({// 				filePath: `file://${e.target.fileName}`,// 			})// 		}// 	}// });}writer.write(data);}, writerErr => {resolve(500)uni.showToast({title: '导出文件失败,请检查是否有权限',icon: 'none'});})})})})}, fsErr => {uni.showToast({title: '导出文件失败,请检查是否有权限',icon: 'none'});})})// #endif	
}// #ifdef APP-PLUS
let submitCsv = savedata.map(e=> JSON.stringify(e)).join("\n")saveCsv(submitCsv,`${user}/triallist/${_this.trialId}`,`${user}/triallist/${_this.trialId}/scoresubmit.csv`).then(path=>{console.log(path)
})
// #endif

2. read 读取

function readListCsv(path){let reader = null;let data=[];// #ifdef APP-PLUSreturn new Promise((resolve, reject) => {plus.io.requestFileSystem(plus.io.PUBLIC_DOCUMENTS,fs => {fs.root.getFile(path,{create:true},fileEntry=> {fileEntry.file( function ( file ) {reader = new plus.io.FileReader();reader.onloadend = function ( e ) {if(e.target.result){//返回的data处理取决于存入时的操作,不同格式不同操作data = e.target.result.split('\n').map(e=> JSON.parse(e))resolve(data);}else{data = []resolve(data);}};reader.readAsText( file );}, function ( e ) {uni.showToast({title: e.message,icon: 'none'});});})})})// #endif
}// #ifdef APP-PLUS
//自定义文件路径
readListCsv(`${user}/triallist/${this.trialId}/time.csv`).then(res=>{console.log(res)
})

3. delete 删除目录

//已存在目录,删除重建
let path = uni.getStorageSync('path') + `/${user}/triallist/${_this.trialId}`;
plus.io.resolveLocalFileSystemURL(path, function( entry ) {let directoryReader = entry.createReader(); //获取读取目录对象directoryReader.readEntries( function( entries ){console.log(entries.length);if (entries.length > 0) {entry.removeRecursively(function(entry) {callback();//删除成功回调---获取不到。。。。    }, function(e) {//错误信息    console.log(e.message + ' ?!')})}})
})

4.upload 上传(uniapp)循环上传目录内文件

// #ifdef APP-PLUS
//使用uniapp上传需要上传文件获取uniapp生成的路径后,调用上传接口
updateResume(){let path = uni.getStorageSync('path') + `/${user}/triallist/${this.trialId}/......`plus.io.resolveLocalFileSystemURL(path, function( entry ) {var directoryReader = entry.createReader(); //获取读取目录对象directoryReader.readEntries( function( entries ){for(let i=0; i < entries.length; i++ ){uni.saveFile({tempFilePath: path + entries[i].name,success: function (res) {uni.uploadFile({url:NEV.BASE_URL +'/api/api..../add',filePath:res.savedFilePath,header: {'X-Access-Token':uni.getStorageSync('token'),'Authorization': 'Bearer ' + uni.getStorageSync('token'),"Content-Type": "multipart/form-data",},name:'MultipartFile',formData: {  //接口携带的参数trialId:_this.trialId,},success() {console.log('一个文件上传成功');},fail() {console.log('一个文件上传失败');}})},fail() {console.log('一个文件上传失败');}});console.log( entries[i].name );}}, function ( e ) {alert( "Read entries failed: " + e.message );} );});// #endif
}

相关文章:

uniapp iosApp H5+本地文件操作(写入修改删除等)

h5 地址 html5plus 以csv文件为例&#xff0c;写入读取保存修改删除文件内容&#xff0c;传输文件等 1.save 文件保存 function saveCsv(data,pathP,path){// #ifdef APP-PLUSreturn new Promise((resolve, reject) > {plus.io.requestFileSystem( plus.io.PUBLIC_DOCUMEN…...

蓝桥杯 字符串和日期

有一个类型的题目是找到输出图形的规律&#xff0c;然后将其实现。观察下面的图形。你想想你该怎么输出这个图形呢? ABBB#include<stdio.h> int main(){printf(" A\n");printf("BBB\n");return 0; }那么&#xff0c;对于如下的图形&#xff1a; ABB…...

Vue13 监视属性

监视属性 当被监视的属性发生变化时&#xff0c;执行定义的函数 监视属性watch&#xff1a; 1.当被监视的属性变化时, 回调函数自动调用, 进行相关操作 2.监视的属性必须存在&#xff0c;才能进行监视&#xff01;&#xff01; 3.监视的两种写法&#xff1a; (1).new Vue时传入…...

会员商城小程序的作用是什么

随着消费升级、用户消费习惯改变及互联网电商高速发展冲击下&#xff0c;传统线下经营商家面临不少痛点&#xff0c;产品销售难、经营营销难、客户管理难等&#xff0c;线下流量匮乏、受地域限制且各方面管理繁琐&#xff0c;线上成为众商家增长赋能的方式。 对商家来说&#x…...

排序算法——希尔排序

一、介绍: 希尔排序是一种可以减少插入排序中数据比较次数的排序算法&#xff0c;加速算法的进行&#xff0c;排序的原则是将数据区分为特定步长的小区块&#xff0c;然后以插入排序算法对小区块内部进行排序&#xff0c;经历过一轮排序则减少步长&#xff0c;直到所有数据都排…...

SpringBoot项目整合MybatisPlus持久层框架+Druid数据库连接池

前言 之前搭建SpringBoot项目工程&#xff0c;所使用的持久层框架不是Mybatis就是JPA&#xff0c;还没试过整合MybatisPlus框架并使用&#xff0c;原来也如此简单。在此简单记录一下在SpringBoot项目中&#xff0c;整合MybatisPlus持久层框架、Druid数据库连接池的过程。 一、…...

导致 JVM 内存泄露的 ThreadLocal 详解

为什么要有 ThreadLocal 当我们在学习JDBC时获取数据库连接时&#xff0c;每次CRUD的时候都需要再一次的获取连接对象&#xff0c;并把我们的sql交给连接对象实现操作。 在实际的工作中&#xff0c;我们不会每次执行 SQL 语句时临时去建立连接&#xff0c;而是会借助数据库连接…...

使用预约小程序app有什么方便之处

一、用户人群广&#xff1a;无论是老年人、残疾人还是上班族&#xff0c;只要有需要&#xff0c;都可以通过该小程序轻松预约服务。例如&#xff0c;行动不便的老年人或残疾人&#xff0c;可以通过小程序约家政服务、医疗护理等服务&#xff0c;省去了亲自前往服务场所的麻烦。…...

【转】ubuntu 安装 OpenCv 4.6脚本 installOCV.sh

摘自 https://github.com/opencv/opencv/issues/22132 好东西&#xff0c;收一下。 installOCV.sh#! /bin/bash VER4.6.0 PYTHON_VERSION3.8 CORES2 echo "Script for installing the OpenCV $VER on Ubuntu 18.04 LTS" echo "Updating the OS..." sudo …...

Android 视图动画与属性动画的区别

Android的视图动画和属性动画在功能和使用上有一些明显的区别。 视图动画主要作用于视图&#xff0c;实现如缩放、旋转等效果。这种动画效果相对固定&#xff0c;只能应用于视图对象&#xff0c;且只能改变视图的大小和位置&#xff0c;而不能真正改变视图的属性。视图动画在A…...

Springboot——jxls实现同sheet多个列表展示

文章目录 前言制定模板1、限定模板数据的范围2、设定报表展示项 编写测试类1、将xls模板文件放于 resource 下的 doc文件夹中2、导入依赖文件3、编写接口和导出逻辑 效果预览结论 前言 在之前的博客中Springboot——使用jxls实现excel模板导出excel&#xff0c;具体说明了jxls…...

分布式软件架构——服务端缓存的三种属性

服务端缓存 在透明多级分流系统中&#xff0c;我们以流量从客户端中发出开始&#xff0c;以流量到达服务器集群中真正处理业务的节点结束。一起探索了在这个过程中与业务无关的一些通用组件&#xff0c;包括DNS、CDN、客户端缓存&#xff0c;等等。 实际上&#xff0c;服务端缓…...

Flink之Watermark策略代码模板

方式作用WatermarkStrategy.noWatermarks()不生成watermarkWatermarkStrategy.forMonotonousTimestamps()紧跟最大事件时间watermark生成策略WatermarkStrategy.forBoundedOutOfOrderness()允许乱序watermark生成策略WatermarkStrategy.forGenerator()自定义watermark生成策略 …...

ubuntu 安装postgresql,增加VECTOR向量数据库插件 踏坑详细流程

PGSQL安装&#xff0c;删除&#xff0c;运行&#xff0c;修改密码流程 Ubuntu18.04安装与配置postgresql含远程连接教程&#xff08;含踩坑记录&#xff09;_sudo apt-get install postgresql-CSDN博客 详细安装流程以上博客&#xff0c;自己也记录下 安装vector扩展连接 声明…...

基于Springboot实现影视影院订票选座管理系统【项目源码+论文说明】分享

基于Springboot实现影视影院订票选座管理系统演示 摘要 本论文主要论述了如何使用JAVA语言开发一个影城管理系统 &#xff0c;本系统将严格按照软件开发流程进行各个阶段的工作&#xff0c;采用B/S架构&#xff0c;面向对象编程思想进行项目开发。在引言中&#xff0c;作者将论…...

mysql批量插入数据,跳过唯一索引报错

数据准备 DROP TABLE IF EXISTS user1; CREATE TABLE user1 ( id INT NOT NULL AUTO_INCREMENT, name VARCHAR(45) NULL, age INT(3) NOT NULL, PRIMARY KEY (id), UNIQUE INDEX u_name (name));insert into user1(name, age) values (zhangshan, 18), (lisi, 19);1. INSERT I…...

论文阅读--Energy efficiency in heterogeneous wireless access networks

异构无线接入网络的能源效率 论文信息&#xff1a;Navaratnarajah S, Saeed A, Dianati M, et al. Energy efficiency in heterogeneous wireless access networks[J]. IEEE wireless communications, 2013, 20(5): 37-43. I. ABSTRACT && INTRODUCTION 本文提出了无…...

Redis的C客户端(hiredis库)使用

文章目录 1、Ubuntu安装redis服务端2、hiredis库的安装3、同步API接口的使用3.1、连接redis数据库redisConnect3.2、发送需要执行的命令redisCommand3.3、redisCommandArgv函数3.4、redisAppendCommand*函数支持管道命令3.5、释放资源3.6、同步连接代码 3.7、异步连接4、redis连…...

光引擎、光模块、光器件之间的关系和区别

最近小编有收到一些用户问“光引擎、光模块、光器件之间的关系和区别&#xff1f;”&#xff0c;众所周知光通信技术一直在不断演进&#xff0c;为满足不断增长的数据传输需求提供了强大的解决方案。而光通信系统中&#xff0c;光引擎、光模块和光器件是关键的组成部分&#xf…...

【办公-excel】两个时间相减 (二) - 带毫秒的时间进行相减操作

一、使用内部函数 1.1 效果展示 TEXT(((RIGHT(TEXT(B2,"yyyy-mm-dd hh:mm:ss.000"),LEN(TEXT(B2,"yyyy-mm-dd hh:mm:ss.000"))-FIND(".",TEXT(B2,"yyyy-mm-dd hh:mm:ss.000")))-RIGHT(TEXT(A2,"yyyy-mm-dd hh:mm:ss.000"),…...

御坂翻译器:3分钟开启你的日语游戏无障碍之旅

御坂翻译器&#xff1a;3分钟开启你的日语游戏无障碍之旅 【免费下载链接】MisakaTranslator 御坂翻译器—Galgame/文字游戏/漫画多语种实时机翻工具 项目地址: https://gitcode.com/gh_mirrors/mi/MisakaTranslator 你是否曾经因为语言障碍而错过了那些精彩的日系游戏剧…...

从手机充电到电路板:一文搞懂Type-C的6P、16P、24P到底该怎么选(附实物图对比)

Type-C接口选型实战指南&#xff1a;6P/16P/24P的工程决策逻辑 当你在设计一款智能手表时&#xff0c;是否曾纠结过该用6P还是16P的Type-C接口&#xff1f;这个问题看似简单&#xff0c;却直接影响着产品的BOM成本、用户体验和市场竞争力。作为硬件开发者&#xff0c;我们每天都…...

Treelink选择工具:基于树形结构与链接关系的智能对象筛选方案

1. 项目概述&#xff1a;为什么我们需要“简化模拟选择”&#xff1f;在仿真分析、游戏开发、影视特效乃至工业设计领域&#xff0c;“模拟选择”是一个高频且令人头疼的操作。无论是为3D场景中的一片森林批量设置风力参数&#xff0c;还是在电路仿真中挑选特定节点进行信号分析…...

5分钟快速上手:OBS实时字幕插件终极配置指南

5分钟快速上手&#xff1a;OBS实时字幕插件终极配置指南 【免费下载链接】OBS-captions-plugin Closed Captioning OBS plugin using Google Speech Recognition 项目地址: https://gitcode.com/gh_mirrors/ob/OBS-captions-plugin 想要为你的直播或录播内容添加专业的实…...

PHPWord替换word模板内容时,存在表格,且不确定表格行数的处理方式

PHPWord替换word模板内容时,存在表格,且不确定表格行数的处理方式 想得到的目标表格 表格可能存在若干行,需要循环生成,插入到word模板中 word模板 实现过程 1、Composer安装 phpword composer require phpoffice/phpword2、实现代码 //模拟数据 $data = [[...

MLT框架的“Producer”到底有多智能?深入loader.dict与avformat揭秘媒体文件自动解析

MLT框架的“Producer”智能解析机制&#xff1a;从loader.dict到avformat的深度探索 当你在MLT框架中写下Producer(profile, nullptr, "video.mp4")这样一行看似简单的代码时&#xff0c;背后其实隐藏着一套精妙的媒体文件自动解析系统。这个系统能够根据文件扩展名、…...

保姆级教程:用ESP32 AT固件实现手机蓝牙配对,从编译到连接一次搞定

ESP32蓝牙开发实战&#xff1a;从固件编译到手机配对的完整指南 在物联网设备开发中&#xff0c;蓝牙连接是最基础也最常用的功能之一。ESP32作为一款高性价比的Wi-Fi/蓝牙双模芯片&#xff0c;凭借其出色的性能和丰富的开发资源&#xff0c;已经成为智能家居、可穿戴设备等领域…...

0502光刻机破局 第五卷:EUV光源系统(S级 长期死磕突破)第2小节:国内外技术参数差距

第五卷&#xff1a;EUV光源系统&#xff08;S级 长期死磕突破&#xff09; 第2小节&#xff1a;国内外技术参数差距&#xff08;全量化对标&#xff0c;ASML vs 国产&#xff0c;死磕数据&#xff09; 前置硬核声明 本节100%量化、100%对标、100%无修饰&#xff0c;直接把 ASML…...

ESPHome安装后,你的第一个智能设备可以不是开关或灯

ESPHome创意实践&#xff1a;从温控风扇到植物管家&#xff0c;解锁智能设备的无限可能 当你完成ESPHome的基础安装后&#xff0c;脑海中浮现的第一个项目是什么&#xff1f;大多数人会想到开关或灯泡——这些确实是智能家居的经典起点。但ESP8266/ESP32开发板的潜力远不止于此…...

手把手教你写JS逆向通用模板:一键提取加密参数

在JS逆向实战中,你一定遇到过这种情况:同一个网站,换个接口就要重新扣代码、调环境、处理依赖;换个网站,又要从头再来一遍,重复劳动浪费大量时间。 其实90%的JS逆向场景,都可以用一套通用模板搞定。不管是MD5/SHA1签名、AES/RSA加密、还是混淆后的动态加密函数,这套模…...