yxxs123 发表于 2015-9-29 10:57:15

sharepoint中的文档库之间的文件操作,列表库之间的列表项操作

大家在操作文档库之间的文档的时候,需要用到打开文档库
SPFolder oFolder = web.GetFolder("Pages");
其实我们这个文档库本来是中文名字,叫做“页面”,可是在代码里面就要写成Pages,还有一个文档库叫做“过期文档”,在代码里面要写成DocLib,这两个名字可以从他们的链接里面看到,需要大家注意。

在下面代码中,我注释掉的就是不同列表库的列表项的拷贝,要注意的就是列表库的名字要用英文(红色部分对应的中文名字为过期新闻,是我们新建的时候写的,代码里面要用英文名字,可以从url中获取到)和列表项的名字(绿色部分)要加上

item.CopyTo(web.Url + "/DocLib/" + item.Name);


static void Main(string[] args)
      {
            SPSecurity.RunWithElevatedPrivileges(
                                             delegate()
                                             {
                                                   using (SPSite site = new SPSite(@"http://virus/sites/intranet"))
                                                   {
                                                       using (SPWeb web = site.AllWebs["team"])
                                                       {
                                                         web.AllowUnsafeUpdates = true;


                                                         //#region 从Pages(中文名字:页面)列表库拷贝/移动文件到DocLib(中文名字:过期新闻)列表库
                                                         //SPList list = web.Lists["页面"];
                                                         //foreach (SPListItem item in list.Items)
                                                         //{
                                                         //    //列表项从一个列表库拷贝到另外一个列表库,列表项不支持移动(MoveTto)
                                                         //    item.CopyTo(web.Url + "/DocLib/" + item.Name);
                                                         //}
                                                         //#endregion



                                                          //从Pages文档库拷贝/移动文件到DocLib文档库
                                                         SPFolder oFolder = web.GetFolder("Pages");
                                                         SPFileCollection collFiles = oFolder.Files;

                                                         for (int intIndex = collFiles.Count - 1; intIndex > -1; intIndex--)
                                                         {
                                                               //文档从一个文档库拷贝到另一个文档库
                                                                   collFiles.CopyTo(web.Url+"/DocLib/" + collFiles.Name);
                                                                   //文档从一个文档库移动到另一个文档库
                                                               collFiles.MoveTo(web.Url+"/DocLib/" + collFiles.Name);
                                                               
                                                         }


                                                         web.AllowUnsafeUpdates = false;
                                                       }
                                                   }
                                             });

            Console.ReadLine();
      }

文档库之间的拷贝是没有问题的,可是当使用自定义列表或者内容类型的时候,就会出现下列错误提示“"找不到源项目。请确认此项目存在,并且您具有读取此项目的权限。”
网上找了半天,原来是sharepoint本身的问题,有国外的家伙写了一个解决方案,链接如下
               http://www.communardo.de/techblog/2008/01/08/sharepoint-listenelement-splistitem-in-eine-andere-liste-kopieren/

其实就是在目标列表中新建一个item,然后逐个栏的拷贝,附件单独拷贝,其他的直接赋值,但是如果两个列表的内容类型不相同的话,会出问题,所以我加上了try catch来处理一下,也就是遇到异常的时候什么都不做,继续下面的操作

添加如下方法
public static SPListItem CopyItem(SPListItem sourceItem, string destinationListName)
      {
            //copy sourceItem to destinationList
            SPList destinationList = sourceItem.Web.Lists;
            SPListItem targetItem = destinationList.Items.Add();
            foreach (SPField f in sourceItem.Fields)
            {
                if (!f.ReadOnlyField && f.InternalName != "Attachments")
                {
                  try{
                  targetItem = sourceItem;
                     }catch{}
                }
            }
            //copy attachments
            foreach (string fileName in sourceItem.Attachments)
            {
                SPFile file = sourceItem.ParentList.ParentWeb.GetFile(sourceItem.Attachments.UrlPrefix + fileName);
                byte[] imageData = file.OpenBinary();
                targetItem.Attachments.Add(fileName, imageData);
            }
            targetItem.Update();
            return targetItem;
      }

使用方式如下


foreach (SPListItem item in list.Items)
                        {
                            CopyItem(item, "已发布公告");
                            //item.Delete();
                        }
页: [1]
查看完整版本: sharepoint中的文档库之间的文件操作,列表库之间的列表项操作