C# 批量复制文件

简介:
前言
    项目之外,公司要求把客户上传的xls数据文件按条件拷贝一份出来,可是这些上传的文件都已经重新命过名,不过还好有上传的记录,包括文件新命名的规则.于是只需要写一个程序来批量获得这些被重新命过名的文件然后拷贝出来就行了.

正题
    我是直接新建的一个aspx并在后台代码里写的,帖cs代码:
using  System;
using  System.Data;
using  System.Configuration;
using  System.Collections;
using  System.Web;
using  System.Web.Security;
using  System.Web.UI;
using  System.Web.UI.WebControls;
using  System.Web.UI.WebControls.WebParts;
using  System.Web.UI.HtmlControls;
using  System.IO;
using  System.Data.SqlClient;

public  partial  class  page_FilesAsEasy : System.Web.UI.Page
{
    
protected   void  Page_Load( object  sender, EventArgs e)
    {
        ArrayList arr 
=   new  ArrayList();
        SqlConnection conn 
=   new  SqlConnection();
        conn.ConnectionString 
=   @" Data Source=.\;Initial Catalog=test;User ID=test;Password=test " ;
        conn.Open();
        
string  sqlcmd;
        sqlcmd 
=   @" select * from test " ;
        SqlCommand cmd 
=   new  SqlCommand(sqlcmd, conn);
        SqlDataReader sdr 
=  cmd.ExecuteReader();
        
while  (sdr.Read())
        {
            FileVO vo 
=   new  FileVO();
            vo.Client_Name 
=  sdr[ " clientname " ].ToString();
            vo.Client_ID 
=  sdr[ " linkshop " ].ToString();
            vo.Category 
=  sdr[ " category " ].ToString();
            vo.Filename 
=  sdr[ " filename " ].ToString();
            arr.Add(vo);
        }
        sdr.Close();
        conn.Dispose();

        Response.Write(
" 开始拷贝文件..<br/><br/> " );
        Response.Flush();

        
foreach  ( object  var  in  arr)
        {
            
try
            {
                FileVO item 
=  (FileVO)var;
                
// 这是经过重新命名的文件的path
                 string  from  =   @" E:\files\ "   +  item.Client_ID.Trim()  +   " _ "   +  item.Category.Trim()  +   " _ "   +  item.Filename.Trim()  +   " .xls " ;
                
string  Category  =   string .Empty;
                
switch  (item.Category)
                {
                    
case   " 1 " :
                        Category 
=   " 出售 " ;
                        
break ;
                    
case   " 2 " :
                        Category 
=   " 出租 " ;
                        
break ;
                    
default :
                        Category 
=   " 购入 " ;
                        
break ;
                }
                
// 重新命名
                 string  to  =   @" F:\xlsdata\ "   +  item.Client_Name.Trim()  +   " _ "   +  Category.Trim()  +   " .xls " ;
                
// 拷贝文件
                File.Copy(from, to,  true );
                
// 设置文件属性
                File.SetAttributes(to, FileAttributes.Normal);
            }
            
catch  (Exception ex)
            {
                Response.Write(ex.Message 
+   " <br/> " );
                
return ;
            }
        }
        Response.Write(
" <br/>拷贝文件结束.. " );
    }
    
class  FileVO
    {
        
private   string  _Client_ID;
        
///   <summary>
        
///  客户代号
        
///   </summary>
         public   string  Client_ID
        {
            
get  {  return  _Client_ID; }
            
set  { _Client_ID  =  value; }
        }

        
private   string  _Category;
        
///   <summary>
        
///  业务类型
        
///   </summary>
         public   string  Category
        {
            
get  {  return  _Category; }
            
set  { _Category  =  value; }
        }

        
private   string  _Filename;
        
///   <summary>
        
///  文件名
        
///   </summary>
         public   string  Filename
        {
            
get  {  return  _Filename; }
            
set  { _Filename  =  value; }
        }

        
private   string  _Client_Name;
        
///   <summary>
        
///  客户名称
        
///   </summary>
         public   string  Client_Name
        {
            
get  {  return  _Client_Name; }
            
set  { _Client_Name  =  value; }
        }
    }
}
注意:
    这里最关键是以下两句代码:
// 拷贝文件
File.Copy(from, to,  true );
// 设置文件属性
File.SetAttributes(to, FileAttributes.Normal);
特别是第二句,我花了许多时间才找到的,如果你不加这句话,那会报以下错误:
The process cannot access the file 'F:\xlsdata\xxx_xxx.xls' because it is being used by another process.

OK!!批量重命名复制成功!



转载:http://www.cnblogs.com/over140/archive/2007/12/07/986326.html

目录
相关文章
C#编程-27:复制文件和目录
C#编程-27:复制文件和目录
C#编程-27:复制文件和目录
C#编程-27:复制文件和目录
122 0
|
Web App开发 C#
|
7月前
|
开发框架 前端开发 .NET
C#编程与Web开发
【4月更文挑战第21天】本文探讨了C#在Web开发中的应用,包括使用ASP.NET框架、MVC模式、Web API和Entity Framework。C#作为.NET框架的主要语言,结合这些工具,能创建动态、高效的Web应用。实际案例涉及企业级应用、电子商务和社交媒体平台。尽管面临竞争和挑战,但C#在Web开发领域的前景将持续拓展。
209 3
|
7月前
|
SQL 开发框架 安全
C#编程与多线程处理
【4月更文挑战第21天】探索C#多线程处理,提升程序性能与响应性。了解C#中的Thread、Task类及Async/Await关键字,掌握线程同步与安全,实践并发计算、网络服务及UI优化。跟随未来发展趋势,利用C#打造高效应用。
203 3
|
1月前
|
C# 开发者
C# 一分钟浅谈:Code Contracts 与契约编程
【10月更文挑战第26天】本文介绍了 C# 中的 Code Contracts,这是一个强大的工具,用于通过契约编程增强代码的健壮性和可维护性。文章从基本概念入手,详细讲解了前置条件、后置条件和对象不变量的使用方法,并通过具体代码示例进行了说明。同时,文章还探讨了常见的问题和易错点,如忘记启用静态检查、过度依赖契约和性能影响,并提供了相应的解决建议。希望读者能通过本文更好地理解和应用 Code Contracts。
33 3
|
23天前
|
设计模式 C# 图形学
Unity 游戏引擎 C# 编程:一分钟浅谈
本文介绍了在 Unity 游戏开发中使用 C# 的基础知识和常见问题。从 `MonoBehavior` 类的基础用法,到变量和属性的管理,再到空引用异常、资源管理和性能优化等常见问题的解决方法。文章还探讨了单例模式、事件系统和数据持久化等高级话题,旨在帮助开发者避免常见错误,提升游戏开发效率。
36 4
|
3月前
|
API C#
C# 一分钟浅谈:文件系统编程
在软件开发中,文件系统操作至关重要。本文将带你快速掌握C#中文件系统编程的基础知识,涵盖基本概念、常见问题及解决方法。文章详细介绍了`System.IO`命名空间下的关键类库,并通过示例代码展示了路径处理、异常处理、并发访问等技巧,还提供了异步API和流压缩等高级技巧,帮助你写出更健壮的代码。
46 2
|
2月前
|
安全 C# 数据安全/隐私保护
实现C#编程文件夹加锁保护
【10月更文挑战第16天】本文介绍了两种用 C# 实现文件夹保护的方法:一是通过设置文件系统权限,阻止普通用户访问;二是使用加密技术,对文件夹中的文件进行加密,防止未授权访问。提供了示例代码和使用方法,适用于不同安全需求的场景。
122 0
|
3月前
|
安全 程序员 编译器
C#一分钟浅谈:泛型编程基础
在现代软件开发中,泛型编程是一项关键技能,它使开发者能够编写类型安全且可重用的代码。C# 自 2.0 版本起支持泛型编程,本文将从基础概念入手,逐步深入探讨 C# 中的泛型,并通过具体实例帮助理解常见问题及其解决方法。泛型通过类型参数替代具体类型,提高了代码复用性和类型安全性,减少了运行时性能开销。文章详细介绍了如何定义泛型类和方法,并讨论了常见的易错点及解决方案,帮助读者更好地掌握这一技术。
81 11