ftp读取txt数据并插入数据库
去官网下载http://enterprisedt.com/ .netftp组件
目前最新版本为2.2.3,下载后在bin目录中找到edtFTPnet.dll,在项目中添加引用。
using EnterpriseDT.Net.Ftp;
public partial class test_ftp : System.Web.UI.Page {
protected void Page_Load(object sender, EventArgs e)
{ if (!IsPostBack)
{
Connect_Ftp();
insertdata();
}
}
#region 连接FTP private static void Connect_Ftp() {
string[] strArray = null;
FTPClient ftp = new FTPClient();
var itccConfig = ConfigFactory.GetConfig<IitccConfig>();
try
{ //以下开始获取FTP数据
ftp.RemoteHost = itccConfig.FTPIp;
ftp.ControlPort = 21;
ftp.Timeout = 0x2710;
ftp.Connect();
ftp.Login(itccConfig.FTPName, itccConfig.FTPPassWord);
ftp.ConnectMode = FTPConnectMode.PASV;
ftp.TransferType = FTPTransferType.ASCII;
ftp.ChDir("/home/ftpuser/itcc/"); //文件夹路径
strArray = ftp.Dir(".", true);
string strDay = DateTime.Now.AddDays(-1).ToString("yyyyMMdd");
//foreach (string strFile in strArray)
//{ //if (strFile.Length >= 0)
//{ //string strfilename = strFile.Substring(0, 24).TrimStart();
string strfilename = "poc_ftp_T04_2015-06-11T0329309.txt";
//if (strfilename == "per" + strDay + ".txt")
//{ // if (CheckIsOver(ConnectionString, strfilename, strDay))
//{ //if (CheckIsInserting(ConnectionString, strfilename, strDay))
//{ //string strLogFile = @"E:\log\upload\copy." + strfilename;
string strLogFile = @"E:\downftp\copy." + strfilename;
if (File.Exists(strLogFile))
File.Delete(strLogFile);
ftp.Get(strLogFile, strfilename);
//ftp.Get(strfilename); //以上为获取FTP数据,并将文件存放在本地硬盘中
//Insert_Date(ConnectionString, null, strDay, strDataInfo, strFilePath + @"/" + strLogFile);//数据插入数据库 // } //} //} //} //}
if (ftp.Connected)
{ ftp.Quit();
}
} catch (Exception ex)
{ if (ftp.Connected)
{ ftp.Quit(); }
throw ex; }
}
#endregion
private static void insertdata() {
FileStream fs = new FileStream("E:/downftp/copy.poc_ftp_T04_2015-06-11T0329309.txt", FileMode.Open, FileAccess.Read, FileShare.ReadWrite);
System.IO.StreamReader my = new System.IO.StreamReader(fs, System.Text.Encoding.UTF8);
string line;
while ((line = my.ReadLine()) != null)
{ //Response.Write(line + "<br />");
string[] mm = line.Split(';');
Insert(mm); }
my.Close();
} private static void Insert(string[] mm)
{ for (int i = 0; i < mm.Length/8; i++)
{ string employeecode = mm[i*8];
string employeename = mm[i*8+1];
string phone1 = mm[i * 8 + 2];
string phone2 = mm[i * 8 + 3];
string phone3 = mm[i * 8 + 4];
string email = mm[i * 8 + 5];
string department = mm[i * 8 + 6];
string workplace = mm[i * 8 + 7];
EmployeeCommand cmd = new EmployeeCommand();
if (cmd.EmployyeeCode(employeecode) == true)
{ cmd.UpdateEmployee(employeecode, employeename, phone1, phone2, phone3, department, workplace, email); }
else { cmd.CreateEmployee(employeecode, employeename, phone1, phone2, phone3, department, workplace, email);
} } }
}
ftp读取txt数据并插入数据库的更多相关文章
- matlab中读取txt数据文件(txt文本文档)
matlab中读取txt数据文件(txt文本文档) 根据txt文档不同种类介绍不同的读取数据方法 一.纯数据文件(没有字母和中文,纯数字) 对于这种txt文档,从matalb中读取就简单多了 例如te ...
- 【hibernate spring data jpa】执行了save()方法 sql语句也执行了,但是数据并未插入数据库中
执行了save()方法 sql语句也执行了,但是数据并未插入数据库中 解决方法: 是因为执行了save()方法,也执行了sql语句,但是因为使用的是 @Transactional 注解,不是手动去提 ...
- SqlBulkCopy将DataTable中的数据批量插入数据库中
#region 使用SqlBulkCopy将DataTable中的数据批量插入数据库中 /// <summary> /// 注意:DataTable中的列需要与数据库表中的列完全一致.// ...
- 多线程查询数据,将结果存入到redis中,最后批量从redis中取数据批量插入数据库中【我】
多线程查询数据,将结果存入到redis中,最后批量从redis中取数据批量插入数据库中 package com.xxx.xx.reve.service; import java.util.ArrayL ...
- list转datatable,SqlBulkCopy将DataTable中的数据批量插入数据库
/// <summary> /// 将泛类型集合List类转换成DataTable /// </summary> /// <param name="list&q ...
- c#逐行分元素读取记事本txt数据写进数据库
其实这里最关键的一个方法是 StreamReader类里的 ReadLine();这个方法可以逐行读取txt流里面的数据.写了个简单的demo,已经加上了详细的注释说明. ok,好了,不废话,下面 ...
- [转] JAVA读取excel数据(插入oracle数据库)
原文地址:http://blog.csdn.net/zczzsq/article/details/16803349 本实例做的是读取execl(只能读取.xls的execl,即只能读取03版的),如果 ...
- java读取本地txt文件并插入数据库
package com.cniia.ny.web.control.configManage; import java.io.BufferedReader; import java.io.File; i ...
- SqlBulkCopy实现大容量数据快速插入数据库中
一般情况下,我们手写sqlhelper类,在此类中定义一个数据插入到数据库的一个方法.将数据库连接密封在using()的语句中.using显示了Idispose接口.可以及时释放数据库连接资源.代码如 ...
随机推荐
- SQL Server 函数执行
在SQL Server 不只是procedure 可以用execute 来执行 function 也是可以的 例子: create function ufn_A( @i as int) returns ...
- Oracle EBS-SQL (SYS-6):sys_在线用户职责查询.sql
/*线用户查询-1*/ SELECT FSAV.USER_NAME,FU.DESCRIPTION,FSAV.RESPONSIBILITY_NAME,FSAV.USER_FORM_NAME,FSAV.L ...
- ubuntu下使用命令行创建一个android项目
在ubuntu中配置好jdk和android_sdk环境后,可以通过命令行方式创建一个android工程. 具体命令如下: android create project --target <ta ...
- Unix/Linux环境C编程入门教程(8) FreeBSD CCPP开发环境搭建
1. FreeBSD是一种自由类Unix操作系统,是由经过BSD.386BSD和4.4BSD发展而来的类Unix的一个重要分支.FreeBSD拥有超过200名活跃开发者和上千名贡献者.FreeBSD被 ...
- S3C6410嵌入式应用平台构建(四)——linux-3.14.4移植到OK6410-(初步启动)
这次,还是把基本的基于我目前最新的Linux源码进行移植到OK6410吧,同时也写下我移植过程中遇到的问题及解决方法,不过有些方法是借鉴网上的,有些是自己加的,会有一些小bug. 一.基本工作 1. ...
- IE6兼容性问题及IE6常见bug详细汇总---转载
1.IE6怪异解析之padding与border算入宽高 原因:未加文档声明造成非盒模型解析 解决方法:加入文档声明<!doctype html> 2.IE6在块元素.左右浮动.设定mar ...
- hdu - 1757 - A Simple Math Problem
题意:当x < 10时, f(x) = x: 当x >= 10 时,f(x) = a0 * f(x-1) + a1 * f(x-2) + + a2 * f(x-3) + …… + a9 ...
- VB6关于判断模态窗体的问题
模态窗体也有人叫模式窗体,是否为模态窗体由Show方法的参数决定: 语法 object.Show style, ownerform Show 方法的语法包含下列部分: 部分 描述 object 可选的 ...
- 设计模式之PHP项目应用——单例模式设计Memcache和Redis操作类
1 单例模式简单介绍 单例模式是一种经常使用的软件设计模式. 在它的核心结构中仅仅包括一个被称为单例类的特殊类. 通过单例模式能够保证系统中一个类仅仅有一个实例并且该实例易于外界訪问.从而方便对实例个 ...
- HDU 3641 Treasure Hunting(阶乘素因子分解+二分)
题目链接:pid=3641">传送门 题意: 求最小的 ( x! ) = 0 mod (a1^b1*a2^b2...an^bn) 分析: 首先吧a1~an进行素因子分解,然后统计下每一 ...