我正在尝试将.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");
}
答案 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);