从外面更新unity需要用的题库
unity中必须要有Plugins文件夹以及dll文件
官方dll文件下载链接: https://archive.codeplex.com/?p=exceldatareader
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using Excel;
using System.IO;
using System.Data;
using OfficeOpenXml; public class Exc_GenXin : MonoBehaviour {
private string DpanMain = "D:/anchor/main.xlsx";//D盘main表格
private string AsstPath;//streaamingAssets文件里面的文件
public static List<DepenceTableDataTwo> DepenceTableDataList = new List<DepenceTableDataTwo>();//创建列表
private void Awake()
{
AsstPath = Application.streamingAssetsPath + "/main.xlsx";
}
private void OnEnable()
{
if (File.Exists(DpanMain))
{
DepenceTableDataList = ReadLoad(DpanMain);
WriteExcel(AsstPath);
Debug.Log("更新成功");
}
} // Use this for initialization
void Start () { }
public void AANniu()
{ }
public struct DepenceTableDataTwo
{
public string itemNumber;//标号
public string topicType;//类型
public string topic;//题目
public string optionA;//A
public string optionB;//B
public string optionC;//C
public string optionD;//D
public string answer;//答案
}
/// <summary>
/// 读取表格
/// </summary>
/// <param name="path">路径</param>
/// <returns></returns>
public static DataSet ReadExcel(string path)
{
FileStream stream = File.Open(path, FileMode.Open, FileAccess.Read, FileShare.Read);
IExcelDataReader excelReader = ExcelReaderFactory.CreateOpenXmlReader(stream);
DataSet result = excelReader.AsDataSet(); return result; }
public static List <DepenceTableDataTwo> ReadLoad(string path)
{
List<DepenceTableDataTwo> _data = new List<DepenceTableDataTwo>();
DataSet resultds = ReadExcel(path);
int rows = resultds.Tables[].Rows.Count;//行
int colums = resultds.Tables[].Columns.Count;//列
for (int i = ; i < rows; i++)
{
DepenceTableDataTwo dependData;
dependData.itemNumber = resultds.Tables[].Rows[i][].ToString();
dependData.topicType = resultds.Tables[].Rows[i][].ToString();
dependData.topic = resultds.Tables[].Rows[i][].ToString();
if (dependData.topicType =="选择")
{
dependData.optionA = resultds.Tables[].Rows[i][].ToString();
dependData.optionB = resultds.Tables[].Rows[i][].ToString();
dependData.optionC = resultds.Tables[].Rows[i][].ToString();
dependData.optionD = resultds.Tables[].Rows[i][].ToString();
dependData.answer = resultds.Tables[].Rows[i][].ToString();
}
else
{
dependData.optionA = string.Empty;
dependData.optionB = string.Empty;
dependData.optionC = string.Empty;
dependData.optionD = string.Empty;
dependData.answer = resultds.Tables[].Rows[i][].ToString();
}
_data.Add(dependData);
}
return _data;
}
/// <summary>
/// 写入表格
/// </summary>
/// <param name="path">路径</param>
public static void WriteExcel(string outpath)
{
FileInfo newFile = new FileInfo(outpath);
if (newFile .Exists )
{
newFile.Delete();
newFile = new FileInfo(outpath);
}
using (ExcelPackage package=new ExcelPackage(newFile))
{
ExcelWorksheet worksheet = package.Workbook.Worksheets.Add("Sheet1");
for (int i = ; i < DepenceTableDataList.Count; i++)
{
worksheet.Cells[i + , ].Value = DepenceTableDataList[i].itemNumber.ToString ();
worksheet.Cells[i + , ].Value = DepenceTableDataList[i].topicType.ToString ();
worksheet.Cells[i + , ].Value = DepenceTableDataList[i].topic.ToString ();
if (DepenceTableDataList[i].topicType == "选择")
{
worksheet.Cells[i + , ].Value = DepenceTableDataList[i].optionA .ToString();
worksheet.Cells[i + , ].Value = DepenceTableDataList[i].optionB .ToString();
worksheet.Cells[i + , ].Value = DepenceTableDataList[i].optionC .ToString();
worksheet.Cells[i + , ].Value = DepenceTableDataList[i].optionD .ToString();
worksheet.Cells[i + , ].Value = DepenceTableDataList[i].answer .ToString();
}
else
{
worksheet.Cells[i + , ].Value = DepenceTableDataList[i].answer.ToString();
}
}
package.Save();
}
}
}
下面附上自己做的Demo地址,不是很完善,但里面也没有错误,大佬们不要介意,感谢!
这是链接:
链接:https://pan.baidu.com/s/1CPLIVsvMzWUknQAi0Ekgjg
提取码:bkod
复制这段内容后打开百度网盘手机App,操作更方便哦
从外面更新unity需要用的题库的更多相关文章
- 更新 | 2019年9月计算机二级office模拟题库
随着2019年上半年计算机二级考试的完美落幕,紧接着的便是9月份的考试了. 到目前为止,下半年9月份计算机二级考试报名开通时间在6月前后,现在也基本结束. 2019年9月(56次)全国计算机等级考试( ...
- Android实训案例(九)——答题系统的思绪,自己设计一个题库的体验,一个思路清晰的答题软件制作过程
Android实训案例(九)--答题系统的思绪,自己设计一个题库的体验,一个思路清晰的答题软件制作过程 项目也是偷师的,决心研究一下数据库.所以写的还是很详细的,各位看官,耐着性子看完,实现结果不重要 ...
- 猿题库 iOS 客户端架构设计
原文: http://mp.weixin.qq.com/s?__biz=MjM5NTIyNTUyMQ==&mid=444322139&idx=1&sn=c7bef4d439f4 ...
- 猿题库 iOS 客户端架构设计-唐巧
序 猿题库是一个拥有数千万用户的创业公司,从20013年题库项目起步到2015年,团队保持了极高的生产效率,使我们的产品完成了五个大版本和数十个小版本的高速迭代. 在如此快速的开发过程中,如何保证代码 ...
- Hibernate考试试题(部分题库)含答案
Hibernate考试试题 (题库) 1. 在Hibernate中,下列说法正确的有( ABC ).[选三项] A.Hibernate是一个开放源代码的对象关系映射框架 B.Hibernate对JD ...
- Ocr答题辅助神器 OcrAnswerer4.x,通过百度OCR识别手机文字,支持屏幕窗口截图和ADB安卓截图,支持四十个直播App,可保存题库
http://www.cnblogs.com/Charltsing/p/OcrAnswerer.html 联系qq:564955427 最新版为v4.1版,开放一定概率的八窗口体验功能,请截图体验(多 ...
- 小学生噩梦——四则运算题库(python 全功能实现)
Github: https://github.com/holidaysss 小组:龙天尧(代码实现),林毓植(浮点转分数函数,代码审查) PSP2.1 Personal Software Proces ...
- Linux题库练习
转一个Linux的题库供自己学习使用(滑稽) 转自:http://www.linuxdiyf.com/view_202485.html 选择题1 在终端下输入mount -a命令的作用是:CA 强制进 ...
- 猿题库 iOS 客户端架构设计(原文地址:http://gracelancy.com/blog/2016/01/06/ape-ios-arch-design/)
猿题库 iOS 客户端架构设计 序 猿题库是一个拥有数千万用户的创业公司,从2013年题库项目起步到2015年,团队保持了极高的生产效率,使我们的产品完成了五个大版本和数十个小版本的高速迭代.在如此快 ...
随机推荐
- 织梦dede如何获取图集调用第一张图片完美解决方法【5.7sp2版本】
制作产品图集多图效果的时候,常常需要获取图集第一张图片的功能,假设获取的是缩略图,那么缩略图不够大的情况下,第一展示效果就会很差,下面来介绍下如何获取调用织梦图集第一张图片的方法: 首先在 inclu ...
- codeforces-1136 (div2)
A.读到第i章,就有N - i + 1章还没读. #include <map> #include <set> #include <ctime> #include & ...
- 从线性模型(linear model)衍生出的机器学习分类器(classifier)
1. 线性模型简介 0x1:线性模型的现实意义 在一个理想的连续世界中,任何非线性的东西都可以被线性的东西来拟合(参考Taylor Expansion公式),所以理论上线性模型可以模拟物理世界中的绝大 ...
- VMware 虚拟机 linux执行 ifconfig 命令 eth0没有IP地址(intet addr、Bcast、Mask) UP BROADCAST MULTICAST 问题
VMware 虚拟机 linux执行 ifconfig 命令 eth0没有IP地址(intet addr.Bcast.Mask) UP BROADCAST MULTICAST 问题 eth0:网络接口 ...
- 移动端-处理后台传过来的html中图片的显示
function DealWithImg() { var width = 0; if (window.screen.width) { width = window.screen.width; } el ...
- 第31月第19天 NV12
1. //设置CIContext,并从CIImage -> CGImage -> UIImage CIContext *context = [CIContext contextWithOp ...
- ansible初识
ansible: 运维自动化的工具, 基本功能, 基于ssh远程连接, 连接验证(ssh-keygen ssh-copy-id ip) 下载: 1. 安装epel源 wget -O /etc/yum ...
- vscode-Live Server的使用心得
一,安装Live Server插件(不详细说明了) 二,开启Server(服务) 有四种方式: 在窗口的最底部有Go Live可以点击,一旦点击,就会自动在浏览器中打开HTML文件 在HTML文件中右 ...
- C# Dictionary 泛型
Dictionary<string, string>是一个泛型,什么是泛型? 使用泛型下面是用泛型来重写上面的栈,用一个通用的数据类型T来作为一个占位符,等待在实例化时用一个实际的类型来代 ...
- 2018-2019-1-20165221&20165225 《信息安全系统设计》实验五:通讯协议设计
2018-2019-1-20165221&20165225 <信息安全系统设计>-实验五:通讯协议设计 OpenSSL学习: 简介: OpenSSL是为网络通信提供安全及数据完整性 ...