解析文件名排列

时间:2015-05-21 14:17:20

标签: c# permutation

我正在尝试将.CSV文件导入我的数据库,该数据库是从图像管理系统导出的表。该系统允许最终用户拍摄图像并(有时)将它们分成多个图像。此报告中有一列表示我正在跟踪的图像的文件名。如果在图像管理系统中拆分项目,则文件名在报告上接收下划线(“_”)。不保留以前的文件名。 CSV上可能存在项目的方式如下所示:

Report 1 @ 8:00AM:  ABC.PNG

Report 2 @ 8:30AM:  ABC_1.PNG
                    ABC_2.PNG 

 Report 3 @ 9:00AM: ABC_1_1.PNG 
                    ABC_1_2.PNG
                    ABC_2_1.PNG
                    ABC_2_2.PNG 

Report 4 @ 9:30AM   ABC_1_1_1.PNG
                    ABC_1_1_2.PNG
                    ABC_1_2.PNG
                    ABC_2_1.PNG
                    ABC_2_2.PNG 

我将每个文件名导入到自己的记录中。当一个项目被拆分时,我想识别以前的版本并更新原始记录,然后将新的拆分记录添加到我的数据库中。知道项目是否被拆分的关键是找到下划线(“_”)。

我不确定要重新创建以前的子名称应该怎么做,我必须测试文件名的每个先前迭代以查看它是否存在。我的问题是解释文件名的当前状态并重建所有以前的可能性。我不需要原始名称,只需要第一个可能的拆分名称,直到当前名称。下面的代码显示了我所得到的内容,但我不确定如何干净利落地完成这项工作。

String[] splitName = theStringToSplit.Split('_');

for (int i = 1; i < splitName.Length - 1; i++)
{
    //should concat everything between 0 and i, not just 0 and I
    //not sure if this is the best way or what I should do

    MessageBox.Show(splitName[0] + "_" + splitName[i] + ".PNG");
}

1 个答案:

答案 0 :(得分:0)

你要找的东西是字符串的一部分。 所以string.Join()可能会帮助您将数组加入分隔字符串: 它还包含参数起始索引和要使用的项目数。

string[] s = new string[] { "2", "a", "b" };
string joined = string.Join("_", s, 0 ,3);

// joined will be "2_a_b"   

也许你正在使用错误的工具来解决问题。如果您想保留最后一个&#34; _&#34;,您可能需要使用LastIndexOf()甚至正则表达式。无论如何:你不应该不必要地撕掉名字并重新粘贴它们。如果完成的话,那就是文化不变而不是文化特定的(可能会有不同的解释&#34; - &#34;或者#34的低写字母;我&#34;。 string fnwithExt =&#34; Abc_12_23.png&#34 ;;

        string fn = System.IO.Path.GetFileName(fnwithExt);
        int indexOf = fn.LastIndexOf('_');
        string part1 = fn.Substring(0, indexOf-1);
        string part2 = fn.Substring(indexOf+1);
        string part3 = System.IO.Path.GetExtension(fnwithExt);

        string original = System.IO.Path.ChangeExtension(part1 + "_"+ part2, part3);