【发布时间】:2015-05-21 14:17:20
【问题描述】:
我正在尝试将 .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");
}
【问题讨论】:
标签: c# permutation