rust calcmine读取excel

use std::fs::{create_dir_all, remove_dir_all};

use std::path::Path;

use std::time::{SystemTime, UNIX_EPOCH};

use calamine::{open_workbook, DataType, Reader, Xlsx, Data};

use rbatis::rbdc::{Error};

use salvo::{Request, Response};

pub async fn import_excel_data(req:&mut Request){

//创建临时文件

create_dir_all("temp").unwrap();

//创建时间戳

let time = SystemTime::now()

.duration_since(UNIX_EPOCH)

.unwrap()

.as_millis();

//从req中获得上传的文件

let file = req.file("file").await;

let mut dest = "".to_string();

if let Some(file) = file {

dest = format!("temp/{}", time.to_string() + "_" + file.name().unwrap_or("file"));

match std::fs::copy(file.path(), Path::new(&dest)) {

Ok(_) => { println!("文件上传拷贝成功"); }

Err(_) => { println!("文件上传拷贝失败"); }

}

}

//导入到具体的实体类

let mut vec_user_import_data: Vec<SysUserEntity> = Vec::new();

let mut workbook: Xlsx<_> = open_workbook(dest).expect("无法读取文件");

match workbook.worksheet_range("员工") {

Ok(worksheet) => {

//跳过第一行表头数据

for row in worksheet.rows().skip(1) {

// 将每一列的数据存入员工实体

if let (Some(Data::String(user_name)),

Some(Data::String(nick_name)),

Some(Data::String(company)),

Some(Data::String(department)),

Some(Data::String(gender)),

Some(Data::String(email)),

Some(Data::String(telephone))) =

(row.get(0), row.get(1), row.get(2), row.get(3), row.get(4), row.get(5), row.get(6)) {

let mut user_entity = SysUserEntity{

user_id: None,

dept_id:Some(dept_id),

user_name: Some(user_name.to_string()),

nick_name: Some(nick_name.to_string()),

user_type: None,

email:Some(email.to_string()),

phone_number :Some(te

相关推荐
古城小栈6 小时前
Rust 迭代器产出的引用层数——分水岭
开发语言·rust
peterfei10 小时前
IfAI v0.2.8 技术深度解析:从"工具"到"平台"的架构演进
rust·ai编程
栈与堆14 小时前
LeetCode-1-两数之和
java·数据结构·后端·python·算法·leetcode·rust
superman超哥14 小时前
双端迭代器(DoubleEndedIterator):Rust双向遍历的优雅实现
开发语言·后端·rust·双端迭代器·rust双向遍历
福大大架构师每日一题15 小时前
2026年1月TIOBE编程语言排行榜,Go语言排名第16,Rust语言排名13。C# 当选 2025 年度编程语言。
golang·rust·c#
superman超哥17 小时前
精确大小迭代器(ExactSizeIterator):Rust性能优化的隐藏利器
开发语言·后端·rust·编程语言·rust性能优化·精确大小迭代器
superman超哥17 小时前
惰性求值(Lazy Evaluation)机制:Rust 中的优雅与高效
开发语言·后端·rust·编程语言·lazy evaluation·rust惰性求值
古城小栈17 小时前
Rust IO 操作 一文全解析
开发语言·rust
superman超哥18 小时前
迭代器适配器(map、filter、fold等):Rust函数式编程的艺术
开发语言·rust·编程语言·rust map·rust filter·rust fold·rust函数式
superman超哥18 小时前
Iterator Trait 的核心方法:深入理解与实践
开发语言·后端·rust·iterator trait·trait核心方法