System.Data.DataTable dt = new System.Data.DataTable();
DataColumn FileName;
DataColumn FileDirectory;
public FrmGetFileDirectory()
{
InitializeComponent();
}
/// <summary>
/// 获取文件目录及文件全称
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btnGetFileDirectory_Click( object sender, EventArgs e)
{
ArrayList list = new ArrayList();
ArrayList FileList = new ArrayList();
System.Data.DataTable ddt=GetFileList( @"D:\TFSWork\Zoes\SRC-InProcess" , "*.*" , list, FileList, true );
Export(ddt, @"D:\Work\工作信息\FileDicre.xlsx" );
}
/// <summary>
/// 首次加载事件
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void FrmGetFileDirectory_Load( object sender, EventArgs e)
{
FileName = new DataColumn( "FileName" , typeof ( string ));
FileDirectory = new DataColumn( "FileDirectory" , typeof ( string ));
dt.Columns.Add(FileName);
dt.Columns.Add(FileDirectory);
}
/// <summary>
///
/// </summary>
/// <param name="strDir">指定路径</param>
/// <param name="strFilePattern">要与strDir 中的文件名匹配的搜索字符串</param>
/// <param name="arrDirs">查询得到的所有目录ArrayList</param>
/// <param name="arrFiles">查询得到的所有文件名称ArrayList</param>
/// <param name="bIsRecursive">是否递归查询</param>
private System.Data.DataTable GetFileList( string strDir, string strFilePattern, ArrayList arrDirs, ArrayList arrFiles, bool bIsRecursive)
{
if ( string .IsNullOrEmpty(strDir))
{ // 参数正确性检查
return dt;
}
DataRow dr = dt.NewRow();
try
{
// 取得指定路径下所有符合条件的文件
string [] strFiles = Directory.GetFiles(strDir, strFilePattern);
// 取得指定路径下所有目录
string [] strDirs = Directory.GetDirectories(strDir);
foreach ( string name in strFiles)
{ // 将所有文件名称加入结果ArrayList中
//arrFiles.Add(name);
string strFileName = GetFileName(name);
dr[FileName] = strFileName; //添加到文件名称:列
dr[FileDirectory]=GetDirectory(name);
}
foreach ( string name in strDirs)
{ // 将所有目录加入结果ArrayList中
arrDirs.Add(name);
//dr[FileDirectory] = name;//添加到文件全目录:列
}
if (strFiles.Length > 0)
dt.Rows.Add(dr); //添加到行
if (bIsRecursive)
{ // 递归
if (strDirs.Length > 0)
{
foreach ( string dir in strDirs)
{ // 递归遍历所有文件夹
GetFileList(dir, strFilePattern, arrDirs, arrFiles, bIsRecursive);
}
}
}
}
catch (Exception e)
{
MessageBox.Show( "报错" + e.Message);
}
return dt;
}
/// <summary>
/// 获取文件名称
/// </summary>
/// <param name="path"></param>
/// <returns></returns>
public static string GetFileName(String path)
{
if (path.Contains( "\\" ))
{
string [] arr = path.Split( '\\' );
return arr[arr.Length - 1];
}
else
{
string [] arr = path.Split( '/' );
return arr[arr.Length - 1];
}
}
/// <summary>
/// 获取文件目录
/// </summary>
/// <param name="filename"></param>
/// <returns></returns>
public static String GetDirectory( string filename)
{
return filename.Substring(0, filename.LastIndexOf( "\\" ));
}
|