去官网下载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数据并插入数据库的更多相关文章

  1. matlab中读取txt数据文件(txt文本文档)

    matlab中读取txt数据文件(txt文本文档) 根据txt文档不同种类介绍不同的读取数据方法 一.纯数据文件(没有字母和中文,纯数字) 对于这种txt文档,从matalb中读取就简单多了 例如te ...

  2. 【hibernate spring data jpa】执行了save()方法 sql语句也执行了,但是数据并未插入数据库中

    执行了save()方法  sql语句也执行了,但是数据并未插入数据库中 解决方法: 是因为执行了save()方法,也执行了sql语句,但是因为使用的是 @Transactional 注解,不是手动去提 ...

  3. SqlBulkCopy将DataTable中的数据批量插入数据库中

    #region 使用SqlBulkCopy将DataTable中的数据批量插入数据库中 /// <summary> /// 注意:DataTable中的列需要与数据库表中的列完全一致.// ...

  4. 多线程查询数据,将结果存入到redis中,最后批量从redis中取数据批量插入数据库中【我】

    多线程查询数据,将结果存入到redis中,最后批量从redis中取数据批量插入数据库中 package com.xxx.xx.reve.service; import java.util.ArrayL ...

  5. list转datatable,SqlBulkCopy将DataTable中的数据批量插入数据库

    /// <summary> /// 将泛类型集合List类转换成DataTable /// </summary> /// <param name="list&q ...

  6. c#逐行分元素读取记事本txt数据写进数据库

    其实这里最关键的一个方法是 StreamReader类里的 ReadLine();这个方法可以逐行读取txt流里面的数据.写了个简单的demo,已经加上了详细的注释说明.   ok,好了,不废话,下面 ...

  7. [转] JAVA读取excel数据(插入oracle数据库)

    原文地址:http://blog.csdn.net/zczzsq/article/details/16803349 本实例做的是读取execl(只能读取.xls的execl,即只能读取03版的),如果 ...

  8. java读取本地txt文件并插入数据库

    package com.cniia.ny.web.control.configManage; import java.io.BufferedReader; import java.io.File; i ...

  9. SqlBulkCopy实现大容量数据快速插入数据库中

    一般情况下,我们手写sqlhelper类,在此类中定义一个数据插入到数据库的一个方法.将数据库连接密封在using()的语句中.using显示了Idispose接口.可以及时释放数据库连接资源.代码如 ...

随机推荐

  1. 弹飞DZY(思维,打表,还没过全,先放着)

    弹飞DZYDescription某天,机智的ZZC发明了一种超级弹力装置,为了在他的朋友DZY面前显摆,他邀请DZY一起玩个游戏.游戏一开始,ZZC在地上沿着一条直线摆上n个装置,每个装置设定初始弹力 ...

  2. Android View动画

    Animation TypeEvaluator View的animate方法 ValueAnimator ObjectAnimator AnimatorSet 使用xml来创建动画 animation ...

  3. javaScript 工作必知(七) 对象继承

    对象继承inherit var o = { r: 1 }; var c = function f() { }; c.prototype = o; c.r = 3; alert(o.r);//被继承的属 ...

  4. SQL学习之汇总数据之聚集函数

    一. 1.我们经常需要汇总数据而不用把他们实际检索出来,为此SQL提供了专门的函数,以便于分析数据和报表生成,这些函数的功能有: (1)确定表中行数(或者满足单个条件或多个条件或包含某个特定值的行数) ...

  5. SqLite 使用 Dapper 查询INTEGER类型的主键问题

    在程序实体定义时: public int TableID { get; set; } 使用Dapper查询SqLite数据库时会报错 Error parsing column (= - Int64) ...

  6. Dictionary<string, string> 排序

    .net framework 2.0 版 Dictionary<string, string> collection = new Dictionary<string, string& ...

  7. 建立一个ROS msg and srv

    msg是一个描述ROS消息字段的简单的文本文件,它们经常用来为消息产生不同语言的源代码. srv文件描述一个服务,它由请求和响应两部分组成. msg文件被存储在一个包的msg目录下,srv文件被存储在 ...

  8. WPF中常用控件的属性

    Source = new BitmapImage( new Uri( WangCaiConfig.GetCurrentDirectory() + imgStr, UriKind.RelativeOrA ...

  9. 【转】CentOS 使用yum命令安装出现错误提示”could not retrieve mirrorlist http://mirrorlist.centos.org ***”

    源自:http://www.cnblogs.com/yangbingqi/p/3328610.html 刚安装完CentOS,使用yum命令安装一些常用的软件,使用如下命令:yum grouplist ...

  10. Archlinux在Btrfs分区上的安装(bios篇)

    其实本文所有的内容在Archwiki上都可以找到,并且更新更全面(只是比较零散),我所做的只是对安装流程做一个小小的总结,每一步我都会稍微解释一下,但不会说的特别详细,毕竟这只是一篇安装引导文,而不是 ...