我正在尝试为返回文件和文件夹列表的 Web 服务构建递归搜索功能。我创建了这两种方法,因此它们充当递归搜索,它首先获取顶级内容,然后将任何文件添加到 fileList,并将任何子文件夹添加到 subFoldersList。我们传入访问级别(在我们的例子中是 root),然后是您想要获取信息的路径。如果找到任何文件夹,则会删除顶部文件夹,因为它已开始搜索该文件夹。然后它调用 processDirectories 方法,该方法将新的路径位置传递回 getFiles 重新开始该过程。现在测试我的文件夹结构如下。当它将第二个文件(profilepic.png)添加到列表中时。我收到错误“集合已修改;枚举操作可能无法执行。”
Photos
picture1.png
TestFolder
profilepic.png
我的代码:
public static List<string> fileList = new List<string>();
public static List<string> subFolderList = new List<string>();
static void processDirectories(string access, string Folder)
{
getFiles(access, Folder);
}
static void getFiles(string access, string Folder)
{
var accessToken = new OAuthToken(token, secret);
var api = new DssAPI(ConsumerKey, ConsumerSecret, accessToken);
var folder = api.GetContents(access, Folder);//Get list from WebService
foreach (var item in folder.Contents)//Contents is an IEnumerable
{
if (item.IsDirectory == true)
subFolderList.Add(item.Path);
else
fileList.Add(item.Path);
}
foreach (var subFolder in subFolderList)
{
subFolderList.RemoveAt(0);
processDirectories(root, subFolder);
}
}