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("\\"));
}