如何从sharepoint列表中获取所有文件夹和项目



我有一个包含文件夹和项目的列表。文件夹是基于文件夹的特定内容类型,但具有属性。

一个文件夹可以包含子文件夹和子项。子文件夹可以包含子文件夹等等。我已经用这种方式获得了所有的项目和文件夹:

    void TraverseList(SPList list)
    {
        Trace.WriteLine("Traversing list: " + list.Title);
        Trace.WriteLine("Base type: " + list.BaseType.ToString());
        TraverseListFolder(list.RootFolder);
    }
    void TraverseListFolder(SPFolder folder)
    {
        SPQuery qry = new SPQuery();
        qry.Folder = folder;
        Trace.WriteLine("Foldername: " + folder.Name);
        SPWeb web = null;
        try
        {
            web = folder.ParentWeb;
            SPListItemCollection ic = web.Lists[folder.ParentListId].GetItems(qry);
            foreach (SPListItem subitem in ic)
            {
                SPFieldLookupValue temp = new SPFieldLookupValue(subitem["TargetPage"].ToString());
                Trace.WriteLine("TargetPage: " + temp);
                Trace.WriteLine("ItemName: " + subitem.Name);
                if (subitem.Folder != null)
                {
                    TraverseListFolder(subitem.Folder);
                }
            }
        }
        catch (Exception ex)
        {
            Trace.WriteLine(ex.Message);
            throw;
        }
        finally
        {
            if (web != null)
            {
                web.Dispose();
            }
        }
    }

这个解决方案的问题是,我必须为每个文件夹发送一个新的查询,当列表增长时,这会变得性能低下。有没有一种方法来获得整个列表与一个调用,而不丢失文件夹/项目结构?

感谢您的阅读!

编辑:使用CAML不是必需的。但是我忘记了一个限制:由于客户的限制,我不能使用webservices。

获取根目录并使用

qry.ViewAttributes = "Scope='RecursiveAll'";

参见:查询获取列表中的所有项目,包括SharePoint子文件夹中的项目

: http://www.ktskumar.com/blog/2009/07/retrieve-all-folders-from-list/

HTH亚历克斯

query.ViewAttributes="Scope='RecursiveAll'";

相关内容

  • 没有找到相关文章

最新更新