最近一直比较忙,答应大家的小程序解析excel一直没有写出来,今天终于忙里偷闲,有机会把这篇文章写出来给大家了。

老规矩先看效果图


效果其实很简单,就是把excel里的数据解析出来,然后存到云数据库里。说起来很简单。但是真的做起来的时候,发现其中要用到的东西还是很多的。不信。。。。 那来看下流程图

流程图


通过流程图,我看看到我们这里使用了云函数,云存储,云数据库。
流程图主要实现下面几个步骤

  • 1,使用wx.chooseMessageFile选择要解析的excel表格
  • 2,通过wx.cloud.uploadFile上传excel文件到云存储
  • 3,云存储返回一个fileid 给我们
  • 4,定义一个excel云函数
  • 5,把第3步返回的fileid传递给excel云函数
  • 6,在excel云函数里解析excel,并把数据添加到云数据库。

可以看到最神秘,最重要的就是我们的excel云函数。

所以我们先把前5步实现了,后面重点讲解下我们的excel云函数。

一,选择并上传excel表格文件到云存储

这里我们使用到了云开发,使用云开发必须要先注册一个小程序,并给自己的小程序开通云开发功能。这个知识点我讲过很多遍了,还不知道怎么开通并使用云开发的同学,去翻下我前面的文章,或者看下我录的讲解视频《5小时入门小程序云开发》

  • 1,先定义我们的页面
    页面很简单,就是一个按钮如下图,点击按钮时调用chooseExcel方法,选择excel

    对应的wxml代码如下
  • 2,编写文件选择和文件上传方法

    上图的chooseExcel就是我们的excel文件选择方法。
    uploadExcel就是我们的文件上传方法,上传成功以后会返回一个fildID。我们把fildID传递给我们的jiexi方法,jiexi方法如下
  • 3 把fildID传递给云函数

二,解下来就是定义我们的云函数了。

  • 1,首先我们要新建云函数

    如果你还不知道如何新建云函数,可以翻看下我之前写的文章,也可以看我录的视频《5小时入门小程序云开发》
    如下图所示的excel就是我们创建的云函数
  • 2,安装node-xlsx依赖库

    如上图所示,右键excel,然后点击在终端中打开。 打开终端后,
    输入 npm install node-xlsx 安装依赖。可以看到下图安装中的进度条

    这一步需要你电脑上安装过node.js并配置npm命令。
  • 3,安装node-xlsx依赖库完成

三,编写云函数

我把完整的代码贴出来给大家

const cloud = require('wx-server-sdk')
cloud.init()
var xlsx = require('node-xlsx');
const db = cloud.database()exports.main = async(event, context) => {let {fileID} = event//1,通过fileID下载云存储里的excel文件const res = await cloud.downloadFile({fileID: fileID,})const buffer = res.fileContentconst tasks = [] //用来存储所有的添加数据操作//2,解析excel文件里的数据var sheets = xlsx.parse(buffer); //获取到所有sheetssheets.forEach(function(sheet) {console.log(sheet['name']);for (var rowId in sheet['data']) {console.log(rowId);var row = sheet['data'][rowId]; //第几行数据if (rowId > 0 && row) { //第一行是表格标题,所有我们要从第2行开始读//3,把解析到的数据存到excelList数据表里const promise = db.collection('users').add({data: {name: row[0], //姓名age: row[1], //年龄address: row[2], //地址wechat: row[3] //wechat}})tasks.push(promise)}}});// 等待所有数据添加完成let result = await Promise.all(tasks).then(res => {return res}).catch(function(err) {return err})return result
}

上面代码里注释的很清楚了,我这里就不在啰嗦了。
有几点注意的给大家说下

  • 1,要先创建数据表

  • 2,有时候如果老是解析失败,可能是有的电脑需要在云函数里也要初始化云开发环境

四,解析并上传成功

如我的表格里有下面三条数据

点击上传按钮,并选择我们的表格文件

上传成功的返回如下,可以看出我们添加了3条数据到数据库

添加成功效果图如下

到这里我们就完整的实现了小程序上传excel数据到数据库的功能了。

再来带大家看下流程图

如果你有遇到问题,可以在底部留言,我看到后会及时解答。后面我会写更多小程序云开发实战的文章出来。也会录制本节的视频出来,敬请关注。

小程序读取excel表格数据,并存储到云数据库相关推荐

  1. 从mysql读取数据保存成excel_小程序读取excel表格数据,并存储到云数据库

    最近一直比较忙,答应大家的小程序解析excel一直没有写出来,今天终于忙里偷闲,有机会把这篇文章写出来给大家了. 老规矩先看效果图 效果其实很简单,就是把excel里的数据解析出来,然后存到云数据库里 ...

  2. excel与云mysql连接数据库_小程序读取excel表格数据,并存储到云数据库

    最近一直比较忙,答应大家的小程序解析excel一直没有写出来,今天终于忙里偷闲,有机会把这篇文章写出来给大家了. 老规矩先看效果图 效果其实很简单,就是把excel里的数据解析出来,然后存到云数据库里 ...

  3. python读取excel表格数据

    python操作excel主要用到xlrd和xlwt两个库,xlrd读取表格数据,支持xlsx和xls格式的excel表格:xlwt写入excel表格数据 一.python读取excel表格数据 1. ...

  4. Qt之如何读取Excel表格数据

    Qt之如何读取Excel表格数据 概述: 代码示例: .pro: 需要包含的头文件: readExcelData.h: readExcelData.cpp: over: 概述: 大家好我是背锅侠&qu ...

  5. linux qt写入excel文件内容,Qt 读取Excel表格数据 生成Excel表格并写入数据

    Qt 读取Excel表格数据 生成Excel表格并写入数据 Qt 读取Excel表格数据 生成Excel表格并写入数据 修改.pro文件,增加 axcontainer QT += axcontaine ...

  6. python 如何读取excel表格数据

    文章目录 前言 python 读取excel 表格 前言 如何用python读取excel表格数据呢 ? python 读取excel 表格 首先需要配置好环境,需要下载 xlrd 包: # 如果不指 ...

  7. 读取EXCEL表格数据到MATLAB成为矩阵

    读取EXCEL表格数据到MATLAB成为矩阵 data=xlsread('filename','sheet','range') 其中,'filename'为文件路径及文件名,'sheet'为数据表名称 ...

  8. Matlab中读取excel表格数据

    一:Matlab中读取excel表格数据步骤讲解: 第二步:  第三步:  第四步:  第五步:  第六步    第七步:  输入之后按回车键,就会出现相应的波形: 效果图:

  9. 使用最新的poi-4.1.0.jar导入导出Excel表格——读取Excel表格数据用法

    使用最新的poi-4.1.0.jar导入导出Excel表格--读取Excel表格数据用法 其中主要的一点心得就是在switch语句哪里进行读取数据转换时,我看到网上的一些用法都是使用 HSSFCell ...

最新文章

  1. tradingview Vue
  2. 使用google云(GCP)二次利用安装kali Linux(kali browser)
  3. C#开发微信门户及应用(8)-微信门户应用管理系统功能介绍
  4. Java编程思想之-主板示例
  5. 【IT笔试面试题整理】丑数
  6. LeetCode 684. 冗余连接(并查集)
  7. 用微型“缝纫机”把芯片无痛“打”进大脑,Elon Musk的脑机帝国拉开序幕!|湾区人工智能...
  8. 使用vue-cli初始化项目时运行‘npm run dev’报错
  9. hibernate框架 最新_Java 15 个框架
  10. 计算机导论电子版_程序员进阶系列:拿下中科大的计算机课程全靠它了!
  11. 《21天学通Java》(ppt+习题答案+源代码)
  12. 创业半年回顾(没饭吃了,我再也不想创业了)
  13. 分页 在mybatis执行SQL语句之前进行拦击处理实例
  14. 【云原生】Kubernetes(k8s)Calico 客户端工具 calicoctl
  15. 直接使用Jlink仿真器下载程序至Freescale K60系列 MCU
  16. 谷歌测试工具_使用Google网站优化工具进行A / B测试的指南
  17. python百度地图标注,Python+百度地图实现地址多点标注--用上BMap了
  18. 【实验2 选择结构】7-9 sdut-C语言实验-三位数整数的各位数字
  19. 白天写代码,晚上驯豹子,就是这么有趣~
  20. i9x系列是服务器CPU吗,i9-10920X和i9-10940X性能实测 CPU性能并不算十分令人满意

热门文章

  1. java随笔三,真正的class大总结
  2. 斯尼格(SING) - 技术也将乌拉圭牛肉推到了最苛刻的市场
  3. 【论文解读|2019】HAHE - Hierarchical Atentive Heterogeneous Information Network Embedding
  4. 网站漏洞修复对DiscuzX3.4论坛总是被篡改页面
  5. 华硕k5555l拆解图解_华硕k555l拆机图解
  6. 2022-2028全球2-氨基-5-甲基吡啶行业调研及趋势分析报告
  7. Xss-reflected/stored跨站脚本分析(Cross site scripting)
  8. springboot执行批量插入_springboot2.1.8+elasticsearch7.3.2(三),添加文档,批量添加文档...
  9. 分类问题——判别分析(LDA、QDA)
  10. 微服务架构Day04-SpringBoot之web开发配置