zoukankan      html  css  js  c++  java
  • sharepoint中的文档库之间的文件操作,列表库之间的列表项操作 Virus


    大家在操作文档库之间的文档的时候,需要用到打开文档库
     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[intIndex].CopyTo(web.Url+"/DocLib/" + collFiles[intIndex].Name);
                                                                       
    //文档从一个文档库移动到另一个文档库
                                                                   collFiles[intIndex].MoveTo(web.Url+"/DocLib/" + collFiles[intIndex].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[destinationListName];
                SPListItem targetItem 
    = destinationList.Items.Add();
                foreach (SPField f 
    in sourceItem.Fields)
                {
                    
    if (!f.ReadOnlyField && f.InternalName != "Attachments")
                    {
                      try{
                        targetItem
    [f.InternalName] = sourceItem[f.InternalName];
                         }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();
                            }

    【Blog】http://virusswb.cnblogs.com/

    【MSN】jorden008@hotmail.com

    【说明】转载请标明出处,谢谢

    反馈文章质量,你可以通过快速通道评论:

  • 相关阅读:
    [转] java代码块 介绍
    win10多用户远程登录
    [读书笔记] learn python the hard way书中 有关powershell 的一些小问题
    Ansible 汇总
    Shell 研究
    Linux CenOS Python3 和 python2 共存
    Ansible安装
    MySQL 5.7.20绿色版安装详细图文教程
    Mysql常用运算符与函数汇总
    mysql 从陌生到熟练之----数据库备份恢复的实现方法
  • 原文地址:https://www.cnblogs.com/virusswb/p/1361198.html
Copyright © 2011-2022 走看看