最近一直比较忙,答应大家的小程序解析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.fileContent

const tasks = [] //用来存储所有的添加数据操作

//2,解析excel文件里的数据

var sheets = xlsx.parse(buffer); //获取到所有sheets

sheets.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与云mysql连接数据库_小程序读取excel表格数据,并存储到云数据库相关推荐

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

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

  2. 小程序读取excel表格数据,并存储到云数据库

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

  3. 微信小程序读取NFC卡片数据,NDEF-M1

    最近来了个离谱的需求,要用微信小程序读写NFC卡数据,微信官方文档可以说是垃圾的一批了,啥都没有,踩了好几天坑把整体思路记录一下. 首先调用微信自带的方法 const adapter = wx.get ...

  4. 云开发实战:小程序导出Ecxcl表格功能

    需求 作为信息收集者需要把用户填写的内容,用Ecxcl表格的方式导出.可以支持在线查看或者复制文件下载链接. 查看 excle 表格可以直接在手机上查看表格 复制下载地址可以通过链接在电脑上下载 实现 ...

  5. python excel写入日期变数字_解决python 读取excel时 日期变成数字并加.0的问题

    excel 文件内容如下: 读取excel内容: import xlrd from datetime import datetime from xlrd import xldate_as_dateti ...

  6. 导出测试点的信号名_小程序导出数据到excel表,借助云开发云函数实现excel数据的保存...

    我们在做小程序开发的过程中,可能会有这样的需求,就是把我们云数据库里的数据批量导出到excel表里.如果直接在小程序里写是实现不了的,所以我们要借助小程序的云开发功能了.这里需要用到云函数,云存储和云 ...

  7. c#后台如何导出excel到本地_小程序导出数据到excel表,借助云开发后台实现excel数据的保存...

    我们在做小程序开发的过程中,可能会有这样的需求,就是把我们云数据库里的数据批量导出到excel表里.如果直接在小程序里写是实现不了的,所以我们要借助小程序的云开发功能了.这里需要用到云函数,云存储和云 ...

  8. js实现excel块拖拉数据_小程序导出数据到excel表,借助云开发云函数实现excel数据的保存...

    我们在做小程序开发的过程中,可能会有这样的需求,就是把我们云数据库里的数据批量导出到excel表里.如果直接在小程序里写是实现不了的,所以我们要借助小程序的云开发功能了.这里需要用到云函数,云存储和云 ...

  9. mysql导入微信小程序云开发_微信小程序-云开发数据库上传json文件

    小程序新增了云开发功能,对于个人开发者是个利好消息.可以省去购买服务器,购买域名以及繁琐配置等步骤,减轻了开发者的负担.至于如何云开发我就不在这里赘述了,请移步微信小程序云开发官方文档,说的很清楚.这 ...

最新文章

  1. Android 学习之pull解析Xml
  2. 我的Go语言学习之旅四:各种变量的声明
  3. 从Hadoop到ClickHouse,现代BI系统有哪些问题?如何解决?
  4. 快速排序和归并排序的区别,Python代码实现
  5. 解决oracle11g连接失败 ORA-01034: ORACLE not available ORA-27101: shared memory realm does not exist
  6. oracle批量新增字段工具,mybatis 中oracle 批量新增三种方法
  7. 去除桌面图标下的底色[XP系统]
  8. IOS github客户端操作流程 超详细
  9. MySQL处理生意参谋_生意参谋低点击率怎么处理?
  10. 极域课堂管理系统软件如何取消控制_极域新品发布会圆满落幕,你想看的都在这里...
  11. 柳州铁一中机器人_柳州铁路第一中学的办学成果
  12. mysql添加索引报错1170 -BLOB/TEXT column ‘xx‘ used in key specification without a key length分析及解决
  13. 解决虚拟机上ubuntu上安装搜狗拼音输入法无法使用的问题,系统是18.04的
  14. 包含头文件使用 书名号与双引号的区别(直接打符号竟然发表不了,太难了)
  15. 冒泡排序的概念和代码范例 Python
  16. win10搜索功能不能用解决方案
  17. 13-津巴布韦-杂项
  18. 机锋网谈毅:开发者是弱势群体(评论)
  19. 简述计算机仿真的基本步骤,计算机仿真技术试卷
  20. 解决方法:MT7628编译OpenWrt固件时quilt错误

热门文章

  1. Ionic项目修改应用图标和启动页
  2. ios 检测是否联网_iOS 设备打开触动精灵提示“您的网络不给力哦,请检查您的设备是否联网”怎么解决?...
  3. easyrecovery15最新版数据恢复类软件测评
  4. Hive经典面试题——级联求和(访客访问统计报表)
  5. 用python按日期将微信文件移动到月份文件夹内
  6. Bzoj4766 文艺计算姬
  7. 永磁同步电机矢量控制(四)——速度环 PI 参数整定(二)
  8. 聊城市普通话水平测试软件音频,聊城市普通话水平测试培训-聊城市教师教育网.ppt...
  9. 基金使用计划 数学建模 matlab,数学建模论文-基金使用计划
  10. 怎么用matlab对图片缩小,使用Matlab实现对图片的缩放