应用.NET控制台应用程序开发批量导入程序。
一.最近一直在调整去年以及维护去年开发的项目,好久没有在进行个人的博客了。每天抽了一定的时间在研究一些开源的框架,Drapper 以及NHibernate以及当前比较流行的SqlSuper框架 并进行对比当前的EF框架。各有优缺点。不多说了。
二.介绍一下批量导入程序的开发。
1.首先找到EXEL的文件的路径进行读取。
2.应用FileInfo进行读取,读取结束EXEL后将EXEL文件进行移动到其他的文件夹里面保存起来。
3.将FileInfo类用于典型的操作,如复制、移动、重命名、创建、打开、删除和追加到文件。
4.许多FileInfo方法在您创建或打开文件时返回其他 I/O 类型。可以使用这些其他类型进一步操作文件。有关更多信息,请参见特定的FileInfo成员,如Open、OpenRead、OpenText、CreateText或Create。
如果打算多次重用某个对象,可考虑使用 FileInfo的实例方法,而不是File类的相应静态方法,因为并不总是需要安全检查。
默认情况下,将向所有用户授予对新文件的完全读/写访问权限。
下表描述了用于自定义各种 FileInfo 方法的行为的枚举。
|
枚举 |
说明 |
|---|---|
|
指定对文件的读取和写入访问。 |
|
|
为已在使用中的文件指定允许的访问级别。 |
|
|
指定是保留还是改写现有文件的内容,并指定创建现有文件的请求是否会导致异常。 |
注意 |
|---|
|
在接受路径作为输入字符串的成员中,路径必须是格式良好的,否则将引发异常。例如,如果路径是完全限定的但以空格开头,则路径在类的方法中不会被修剪。因此,路径的格式不是良好的,并将引发异常。同样,路径或路径的组合不能被完全限定两次。例如,“c:\temp c:\windows”在大多数情况下也将引发异常。在使用接受路径字符串的方法时,请确保路径是格式良好的。 |
5.然后进行逐行读取变可以了。然后我应用的是原始的EF 进行添加的插入数据的效率不高,但是这个一个非常简单的一个程序。
代码如下:
static void Main(string[] args)
{ //进行导入Exel数据
try
{
WxyhData context = new WxyhData(); string fileDir = Properties.Settings.Default.ExcelFileDir;//进行读取Exel的路径
string fishFile = Properties.Settings.Default.FinishedFileDir;//结束的Exel 的路径 List<string> files = FilesGetter.GetFiles(fileDir);//进行获取目录下面的EXEL
int successCount = 0;
int updateCount = 0; #region 1.先判断目录是否为空 if (files.Count() > 0)
{
List<string> processedData = new List<string>(); Console.WriteLine("开始从根目录{0}导入文件", fileDir); #region 2.去掉读取Copy中的文件夹里面的内容 foreach (string fileExc in files)
{
//判断文件是否存在
if (System.IO.File.Exists(fileExc))
{ //如果是以E:\temp\finished 那么就不进行读取否则才进行读取原因是这个是备份的文件
if (fileExc.StartsWith(fishFile) == false)
{
GlobalTools.WriteLog("AutoGetMXIntAcct", 0, "开始从目录:" + fileDir + "导入文件:" + fileExc);
try
{
Workbook book = new Workbook(fileExc);
var cells = book.Worksheets[0].Cells;
//从文件第1行开始读取
var table = cells.ExportDataTableAsString(0, 0, cells.MaxRow + 1, cells.MaxColumn + 1, true); GlobalTools.WriteLog("AutoGetMXIntAcct", 0, "开始从目录:" + fileDir + "导入文件:" + fileExc + ", 共" + table.Rows.Count + "条数据");
#region 3.进行逐条的读取Exel中的每一条的数据进行添加到数据库MX_Int_Acct表中 for (int i = 0; i < table.Rows.Count; i++)
{
#region 3.进行读取Exel
var row = table.Rows[i];
string sys_CifCode = "";//手机号码
string sysAccount = ""; //身份证号
int balance = 0;
string acctName = "";
try
{
sys_CifCode = ((string)row["手机号码"]).Trim();
balance = int.Parse((row["活动积分"]).ToString().Trim());
acctName = ((string)row["显示名称"]).Trim() ?? string.Empty;
sysAccount = ((string)row["身份证号码"]).Trim();
}
catch
{
sysAccount = string.Empty;
acctName = string.Empty;
}
int count = context.MX_INT_ACCT.Where(p => p.SYS_CIF_CODE == sys_CifCode).Count();
//如果存在记录就就行更新否则就就行插入的动作.
if (count > 0)
{
MX_INT_ACCT mxIntAcct = context.MX_INT_ACCT.Where(p => p.SYS_CIF_CODE == sys_CifCode).FirstOrDefault();
mxIntAcct.ACCT_NAME = acctName;
mxIntAcct.BALANCE = balance;
mxIntAcct.SYS_CIF_CODE = sys_CifCode;
mxIntAcct.UPDATE_DATE = DateTime.Now;
mxIntAcct.SYS_ACCOUNT = sysAccount;
updateCount++;
Console.WriteLine("更新成功{0}数据", updateCount); }
else
{
if (processedData.Contains(sys_CifCode))
{
continue;
}
processedData.Add(sys_CifCode);
MX_INT_ACCT mxIntAcct = IntitalMxIntAcct(acctName, balance, sysAccount, sys_CifCode);
context.MX_INT_ACCT.AddObject(mxIntAcct);
successCount++;
Console.WriteLine("导入成功{0}数据", successCount);
}
#endregion
} using (TransactionScope trans = new TransactionScope(TransactionScopeOption.Required))
{
context.SaveChanges();
trans.Complete();
}
#endregion
} catch (Exception ex)
{
GlobalTools.WriteLog("AutoGetMXIntAcct", 0, "异常消息" + ex.ToString());
GlobalTools.WriteErrLog("AutoGetMXIntAcct", ex);
}
} else
{
Console.WriteLine(@"E:\temp\File目录中的备份的文件不进行读取!");
} }
} #endregion
} #endregion
//Exel文件删除
FileInfoExc(files);
} catch (Exception ex)
{
GlobalTools.WriteLog("AutoMxAcctInt", 0, "错误的日志" + ex.ToString());
}
} /// <summary>
///将添加的文件进行保存到指定目录以及当前的文件进行删除
/// </summary>
/// <param name="files"></param>
private static void FileInfoExc(List<string> files)
{
foreach (string fileExc in files)
{
FileInfo fileInfo = new FileInfo(fileExc);
string copyfileDir = Properties.Settings.Default.FinishedFileDir;
string copypath = copyfileDir + "\\" + fileInfo.Name + "-copy-" + DateTime.Now.ToString("yyyy-MM-dd-HHmmss");
//File.Move(fileExc, copypath);
File.Move(fileExc, copypath);
//File.Copy(fileExc, copypath);
File.Delete(fileExc);
GlobalTools.WriteLog("AutoGetMXIntAcct", 0, "文件移动到:" + copypath);
}
}
应用.NET控制台应用程序开发批量导入程序。的更多相关文章
- 应用控制台应用程序开发批量导入EXEL程序。
一.最近一直在调整去年以及维护去年开发的项目,好久没有在进行个人的博客了.每天抽了一定的时间在研究一些开源的框架,Drapper 以及NHibernate以及当前比较流行的SqlSuper框架 并进行 ...
- [小程序开发] 微信小程序内嵌网页web-view开发教程
为了便于开发者灵活配置小程序,微信小程序开放了内嵌网页能力.这意味着小程序的内容不再局限于pages和large,我们可以借助内嵌网页丰富小程序的内容.下面附上详细的开发教程(含视频操作以及注意事项) ...
- 微信小程序开发 [01] 小程序基本结构和官方IDE简介
1.小程序账户注册 实际上在进行开发时没有注册小程序账户也是可以的,官方提供的IDE提供实时编译模拟预览,和当前你有没有绑定小程序账户没有关系. 当然,最终你要正式上线你的小程序的话,肯定还是需要账户 ...
- 小程序开发-微信小程序开发入门
分享一个微信小程序开发的基本流程,仅供参考. 第一步:注册微信小程序公众号,注册成功后,登录微信公众号管理后台,等待下一步操作. 第二步:进入微信小程序的后台后,下载微信内置的微信小程序开发者工具,以 ...
- Spark程序开发-环境搭建-程序编写-Debug调试-项目提交
1,使用IDEA软件进行开发. 在idea中新建scala project, File-->New-->Project.选择Scala-->Scala 2,在编辑窗口中完成Word ...
- Winform 快速开发框架,上位机开发,工控机程序开发,CS程序开发
1.当客户让你做个CS程序时,当你手上一穷二白,所有都要重复造轮,你是不是很烦. 2.但如果有一个通用的,快速开发框架,就可以把你从这些基础的工作解救出来,你专注做业务就好了. 3.本人其中一个项目的 ...
- [小程序开发] 微信小程序audio音频播放组件+api_wx.createAudioContext
引言: audio是微信小程序中的音频组件,可以轻松实现小程序中播放/停止音频等自定义动作. 附上微信小程序audio组件的相关属性说明:https://mp.weixin.qq.com/debug/ ...
- 微信小程序开发——修改小程序原生checkbox、radio默认样式
复选框: 闲话少说,这里直接介绍如何修改小程序提供的复选框的样式,如原生的是这样的: 需要的是这样的: 示例代码: /*复选框外框样式*/ checkbox .wx-checkbox-input { ...
- 微信小程序开发——微信小程序下拉刷新真机无法弹回
开发工具中下拉之后页面回弹有一定的延迟,这个时间也有点久.真机测试,下拉后连回弹都没有,这个问题要解决,就得在下拉函数里加上停止下拉刷新的API,如下: /** * 下拉刷新 */ onPullDow ...
随机推荐
- Linux 系统的用户和组详解_【all】
1.Linux 用户和用户组详解 2.Linux 文件特殊权限详解 3.Linux 文件的读写执行权限的说明 4.Linux 架构之简述企业网站 5.Linux 环境变量设置详解 6.企业生产环境用户 ...
- win10WLAN没有有效的ip配置
方案一:将路由器和猫重启一下,一般都可以解决了!方案二:1.在开始菜单上单击鼠标右键,选择“命令提示符(管理员)”,如果没有找到这个选项,通过cortana搜索cmd,右键以管理员身份运行,还可以进入 ...
- javascript unshift()和shift()
<html> <head> <meta http-equiv="Content-Type" content="text/html; char ...
- libc.so.6: cannot open shared object file: No such file or diretory
环境 centos6.6. 由于误操作 删除了 rm -f /lib64/libc.so.6 导致其他命令不能使用 解决方法: /sbin/sln /lib64/libc-
- JPA规范实现
JPA全称Java Persistence API.JPA通过JDK 5.0注解或XML描述对象-关系表的映射关系,并将运行期的实体对象持久化到数据库中. JPA 是 JCP定义的一种规范,要使用此规 ...
- 【理解】 Error 10053和 Error 10054
1. 10053 这个错误码的意思是: A established connection was aborted by the software in your host machine, 一个已建 ...
- ansible.md
ansible 测试环境配置 注意:192.168.100.201这台机器是主控机,剩下的192.168.100.202.192.168.100.203.192.168.100.210均为测试主机. ...
- SQLServer2008导出表数据为SQL脚本
SQLServer2008的导出脚本方法: 数据库名-->右键 任务-->生存脚本 之后弹出SQLServer脚本生成向导 选择数据库 把编写数据可脚本这一项改为true,默认是false ...
- 利用Python实现12306爬虫--查票
在上一篇文章(http://www.cnblogs.com/fangtaoa/p/8321449.html)中,我们实现了12306爬虫的登录功能,接下来,我们就来实现查票的功能. 其实实现查票的功能 ...
- Linux磁盘分区和挂载
Linux磁盘分区和挂载 分区 分区的方式: mbr分区 最多支持4个主分区 系统只能安装到主分区上 扩展分区要占用一个主分区 MBR最大支持2TB,但拥有最好的兼容性 gtp分区 支持无线多个主分区 ...
注意