unity读写本地excel_2024.4.22

ops/2024/12/22 0:36:04/

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using OfficeOpenXml;
using System.IO;
using Excel;
using System.Data;
using System;
/// <summary>
/// https://blog.csdn.net/Xz616/article/details/128893023
/// Unity3D操作数据之Excel表操作(创建、读取、写入、修改)
/// 北斗课题 VR 设备统计功能开发——每次程序打开关闭记录对应时间到本地电子表格
/// 列:打开年,月,日,时间,关闭年,月,日,时间
/// </summary>
public class ExcelOperation : MonoBehaviour
{// [SerializeField]string strExcelSavePath = "";[SerializeField]string strFilename = "北斗VR设备统计.xlsx";// Start is called before the first frame updatevoid Start(){//strExcelSavePath = Application.streamingAssetsPath;}/// <summary>/// 增/// Application.dataPath   :           E:/UnityProject_V2020.3.47f3c1/BDProject/Assets/// Application.streamingAssetsPath    :/UnityProject_V2020.3.47f3c1/BDProject/Assets/StreamingAssets/// </summary>public void CreatExcel(){//文件地址FileInfo newFile = new FileInfo(strExcelSavePath + "/test.xlsx");//如果文件存在删除重建if (newFile.Exists){newFile.Delete();newFile = new FileInfo(strExcelSavePath + "/test.xlsx");}//数据操作//如果只想创建文件不写入表头,数据操作步骤可以省略using (ExcelPackage package = new ExcelPackage(newFile)){//初次创建增加数据操作(重点在于这条操作语句不同)ExcelWorksheet worksheet = package.Workbook.Worksheets.Add("test");//添加对应列名worksheet.Cells[1, 1].Value = "列名1";worksheet.Cells[1, 2].Value = "列名2";worksheet.Cells[1, 3].Value = "列名3";//保存package.Save();print("创建成功");}}/// <summary>/// 存/// </summary>public void WriteExcel(){//文件地址FileInfo newFile = new FileInfo(strExcelSavePath + "/test.xlsx");//数据操作using (ExcelPackage package = new ExcelPackage(newFile)){//增加数据操作(重点在于这条操作语句与初次创建添加数据不同)ExcelWorksheet worksheet = package.Workbook.Worksheets["test"];//添加第二行数据worksheet.Cells[2, 1].Value = "名称1";worksheet.Cells[2, 2].Value = "价格1";worksheet.Cells[2, 3].Value = "销量1";//添加第三行数据worksheet.Cells[3, 1].Value = "名称2";worksheet.Cells[3, 2].Value = "价格2";worksheet.Cells[4, 3].Value = "销量2";//保存package.Save();print("写入数据成功");}}/// <summary>/// 已知已有行数,添加一行新数据,供外部调用/// dt为开始时间/// </summary>public void AddStartTimeToExcel(){if (!isSaveExcel){ //文件地址FileInfo newFile = new FileInfo(strExcelSavePath + "/" + strFilename);//数据操作using (ExcelPackage package = new ExcelPackage(newFile)){//增加数据操作(重点在于这条操作语句与初次创建添加数据不同)ExcelWorksheet worksheet = package.Workbook.Worksheets["设备统计"];//添加第curRows(原行数当现索引用)行数据  Cells[x,y]//x,y都是从1开始数的curRows++;worksheet.Cells[curRows, 1].Value = (curRows - 1).ToString();worksheet.Cells[curRows, 2].Value = DateTime.Now.Year;worksheet.Cells[curRows, 3].Value = DateTime.Now.Month;worksheet.Cells[curRows, 4].Value = DateTime.Now.Day;worksheet.Cells[curRows, 5].Value = DateTime.Now.ToString("HH:mm:ss");//保存package.Save();isSaveExcel = true;print("写入开始时间到excel");}}}/// <summary>/// 给系统一登录新增的那一行数据的最后一列新增内容——存储结束时间/// </summary>public void AddEndTimeToExcel(){if (isSaveExcel){ //文件地址FileInfo newFile = new FileInfo(strExcelSavePath + "/" + strFilename);//数据操作using (ExcelPackage package = new ExcelPackage(newFile)){//增加数据操作(重点在于这条操作语句与初次创建添加数据不同)ExcelWorksheet worksheet = package.Workbook.Worksheets["设备统计"];//添加第curRows(原行数当现索引用)行数据  Cells[x,y]//x,y都是从1开始数的// curRows = curRows++;// worksheet.Cells[curRows, 1].Value = (curRows - 1).ToString();worksheet.Cells[curRows, 6].Value = DateTime.Now.Year;worksheet.Cells[curRows, 7].Value = DateTime.Now.Month;worksheet.Cells[curRows, 8].Value = DateTime.Now.Day;worksheet.Cells[curRows, 9].Value = DateTime.Now.ToString("HH:mm:ss");//保存package.Save();isSaveExcel = false;print("写入结束时间到excel");}}}/*/// <summary>/// 删改 from csdn/// </summary>public void ChangeExcel(){//文件地址FileInfo newFile = new FileInfo(strExcelSavePath + "/test.xlsx");//数据操作using (ExcelPackage package = new ExcelPackage(newFile)){ExcelWorksheet worksheet = package.Workbook.Worksheets["test"];//追加worksheet.Cells[4, 1].Value = "名称3";worksheet.Cells[4, 2].Value = "价格3";worksheet.Cells[4, 3].Value = "销量3";//删除某一列(参数:列的序号)worksheet.DeleteColumn(1);//删除某一行(参数:行的序号)worksheet.DeleteRow(1);//修改(和添加一样)worksheet.Cells[4, 1].Value = "修改名称";worksheet.Cells[4, 2].Value = "修改价格";worksheet.Cells[4, 3].Value = "修改销量";//保存package.Save();print("删改数据成功");}}*//// <summary>/// 第一次存开始时间的时候不变此值,存结束时间的时候变/// </summary>bool isSaveExcel = false;/// <summary>/// 系统刚打开查询表格看看表格中总行数,也就是即将添加的行的索引/// </summary>int curRows = 0;/// <summary>/// 系统刚打开查询表格看看表格中总行数,也就是即将添加的行的索引/// </summary>int curColumns = 0;/* /// <summary>/// 查 from csdn/// </summary>public void ReadExecel(){//加载文件FileStream fileStream = File.Open(strExcelSavePath + "/test.xlsx", FileMode.Open, FileAccess.Read);IExcelDataReader excelDataReader = ExcelReaderFactory.CreateOpenXmlReader(fileStream);DataSet result = excelDataReader.AsDataSet();// 获取表格有多少列int columns = result.Tables[0].Columns.Count;// 获取表格有多少行 int rows = curRows = result.Tables[0].Rows.Count;Debug.Log("共有:" + columns + "列 " + rows + "行");//第一行为表头,不读取。没有表头从0开始(获取数据)for (int i = 0; i < rows; i++){for (int j = 0; j < columns; j++){// 获取表格中指定行指定列的数据 string value = result.Tables[0].Rows[i][j].ToString();Debug.Log(value);}}fileStream.Close();print("查询数据成功");}*//// <summary>/// 读取本地excel,为了填充变量 curRows,获取当前行数/// </summary>/// <param name="fileName">含文件后缀:北斗VR设备统计.xlsx</param>public void ReadExecel(){//加载文件FileStream fileStream = File.Open(strExcelSavePath + "/" + strFilename, FileMode.Open, FileAccess.Read);IExcelDataReader excelDataReader = ExcelReaderFactory.CreateOpenXmlReader(fileStream);DataSet result = excelDataReader.AsDataSet();// 获取表格有多少列int columns = curColumns = result.Tables[0].Columns.Count;// 获取表格有多少行 int rows = curRows = result.Tables[0].Rows.Count;Debug.Log("共有:" + columns + "列 " + rows + "行");/* //第一行为表头,不读取。没有表头从0开始(获取数据)for (int i = 0; i < rows; i++){for (int j = 0; j < columns; j++){// 获取表格中指定行指定列的数据 string value = result.Tables[0].Rows[i][j].ToString();Debug.Log(value);}}*/fileStream.Close();//print("查询数据成功,行数:" + curRows);}// Update is called once per framevoid Update(){/*if (Input.GetKeyUp(KeyCode.U)){print(Application.streamingAssetsPath);CreatExcel();}if (Input.GetKeyUp(KeyCode.I)){WriteExcel();}*//*if (Input.GetKeyUp(KeyCode.O)){ReadExecel();AddStartTimeToExcel();}if (Input.GetKeyUp(KeyCode.P)){AddEndTimeToExcel();}*/}/// <summary>/// DontDestroyOnLoad(GameObject);//让此物体在场景销毁的时候不进行销毁,但是有几点需要注意//再次返回到此物体所在场景的时候,这个脚本所在的物体也会进行初始化,执行Awake(),Start()方法,所以要设计成单例的://注意看注释/// </summary>private static ExcelOperation _instance;   // 单例public ExcelOperation GameManagerInstance{get { return _instance; }}void Awake(){if (_instance != null){//这里一定要是销毁this.gameObjectDestroy(this.gameObject);return;}//这句话只执行一次,第二次上面return了_instance = this;strExcelSavePath = Application.streamingAssetsPath;ReadExecel();AddStartTimeToExcel();DontDestroyOnLoad(gameObject);}private void OnApplicationQuit(){AddEndTimeToExcel();}
}


http://www.ppmy.cn/ops/23278.html

相关文章

基于vue+node+mysql的视频校对系统

一、登录注册&#xff1a;包括登录&#xff0c;注册&#xff0c;忘记密码&#xff0c;验证码等常用点。 二、用户管理&#xff1a;包括用户的增删改查 三、权限管理&#xff08;请增加这个权限&#xff1a;任务分配——只有管理者才能发布和删除任务&#xff1b;管理员设置。 四…

操作系统安全:Windows与Linux的安全标识符,身份鉴别和访问控制

「作者简介」:2022年北京冬奥会网络安全中国代表队,CSDN Top100,就职奇安信多年,以实战工作为基础对安全知识体系进行总结与归纳,著作适用于快速入门的 《网络安全自学教程》,内容涵盖系统安全、信息收集等12个知识域的一百多个知识点,持续更新。 操作系统有4个安全目标…

美国言语听力学会(ASHA)关于非处方 (OTC) 助听器的媒体声明(翻译稿)

美国国会于 2021 年 4 月 13 日批准美国听力学会积极提供建议&#xff0c;并一直积极参与制定FDA关于非处方助听器销售的拟议法规。根据2017年通过的立法授权。学院积极参与帮助塑造授权立法&#xff0c;并就即将出台的条例分享了建议。 根据美国卫生与公众服务部NIH / NIDCD的…

商用清洁机器人的工作原理介绍

商用清洁机器人是清洁机器人的一种&#xff0c;其主要应用于大型商场&#xff0c;办公室&#xff0c;医院&#xff0c;政府部门等。现将其主要工作原理和组成部分介绍如下。 其主要组成部分为&#xff0c;行走轮子左右各两个&#xff0c;万向轮一个&#xff0c;是基本的轮式结构…

JVM(Java虚拟机)功能特点、垃圾回收机制

简介 JVM&#xff08;Java虚拟机&#xff09;是一种虚拟的计算机执行环境&#xff0c;用于执行Java字节码。Java虚拟机不仅仅用于执行Java语言编写的程序&#xff0c;还可以执行其他编译成Java字节码的语言&#xff08;如Kotlin、Scala等&#xff09;编写的程序。JVM的主要目标…

go圣经 ——方法

这里只是记录了自己学过一遍但是在圣经&#xff08;狼吞虎咽&#xff09;中又看到的新鲜玩意 我们又称之为选择器 package mainimport "fmt"type Rect struct {width, height float64 }// 定义一个方法来计算矩形的面积 func (r Rect) Area() float64 {return r.wi…

二分搜索法

给定已经按照升序排好序的n个元素A[0,n-1]&#xff0c;现要在这n个元素中找出一特定元素x 1.此时数组A是排好序的&#xff0c;我们要根据二分法来找出x&#xff0c;先将数组分成两部分&#xff0c;数组的开始left,数组的结束right,中间位置为mid.此时数组的左边部分为A[left,m…

实验案例一:在一台交换机上配置VLAN

实验环境 实验拓扑图结构如图 12.12所示&#xff0c;其中PC1和PC3属于 VLAN 2&#xff0c;PC2 属于 VLAN 3.PC1 的IP地址为192.168.0.2/24&#xff0c;PC2的P地址为192.168.1.2/24&#xff0c;PC3的P地址为192.168.0.3/24.