Копировать элементы списка из одного списка в другой в sharepoint
В Sharepoint как вы можете скопировать элемент списка из одного списка в другой список
например, копировать из "списка A" в "список B" (оба находятся в корневом каталоге сайта).
Я хочу, чтобы это копирование произошло, когда новый элемент списка добавлен в "Список A"
Я попытался использовать метод CopyTo() для объекта SPListItem внутри получателя событий ItemAdded, но не смог определить URL-адрес для копирования.
Ответы
Ответ 1
Действительно, как сказал Ларс, может быть сложно перемещать элементы и сохранять версии и исправлять userinfo. Я делал схожие вещи с этим раньше, поэтому, если вам нужны примеры кода, дайте мне знать через комментарий и можете предоставить вам некоторые рекомендации.
Метод CopyTo (если вы решите пойти с этим) нуждается в абсолютном Uri:
http://host/site/web/list/filename.doc
Итак, если вы выполняете это в приемнике событий, вам нужно конкатенировать строку, содержащую необходимые элементы. Что-то вроде (обратите внимание, что это можно сделать другими способами):
string dest=
siteCollection.Url + "/" + site.Name + list.Name + item.File.Name;
Ответ 2
Вот код, который я использую. Передайте ему SPlistItem и имя целевого списка, как показано в Sharepoint (Not URL). Единственное ограничение состоит в том, что оба списка должны находиться на одном сайте:
private 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) {
//Copy all except attachments.
if (!f.ReadOnlyField && f.InternalName != "Attachments"
&& null != sourceItem[f.InternalName])
{
targetItem[f.InternalName] = sourceItem[f.InternalName];
}
}
//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);
}
return targetItem;
}
Ответ 3
Копирование и перемещение файлов, элементов и папок в SharePoint может быть сложным, если вы хотите сохранить все метаданные, временные метки, информацию об авторе и историю версий. Посмотрите CopyMove для SharePoint - он также имеет API веб-сервисов.
Ответ 4
Здесь много инструментов для копирования элемента списка в другой список (avepoint, metavis и т.д.), но они довольно дороги, если вы планируете делать это только в одном списке.
Если вы можете сделать это вручную один раз в неделю, например, посмотрите на следующий инструмент: http://en.share-gate.com/sharepoint-tools/copy-move-sharepoint-list-items-with-metadata-and-version-history
Ответ 5
Убедитесь, что вы вызываете метод CopyTo (url) в SPFile, а не в SPListItem.
например:
ItemUpdated(SPItemEventProperties properties)
{
//...
string url = properties.Web.Site.Url + "/" + properties.Web.Name + "Lists/ListName/" + properties.ListItem.File.Name;
//properties.ListItem.File.MoveTo(url);
properties.ListItem.File.CopyTo(url);
//...
}
Ответ 6
private void CopyAttachmentsToList(SPListItem srcItem, SPListItem tgtItem)
{
try
{
//get source item attachments from the folder
SPFolder srcAttachmentsFolder =
srcItem.Web.Folders["Lists"].SubFolders[srcItem.ParentList.Title].SubFolders["Attachments"].SubFolders[srcItem.ID.ToString()];
//Add items to the target item
foreach (SPFile file in srcAttachmentsFolder.Files)
{
byte[] binFile = file.OpenBinary();
tgtItem.Update();
tgtItem.Attachments.AddNow(file.Name, binFile);
tgtItem.Update();
}
}
catch
{
//exception message goes here
}
finally
{
srcItem.Web.Dispose();
}
}
Не забудьте добавить эту строку, tgtItem.Update();
, иначе вы получите ошибку.
Ответ 7
Итак, списки имеют одинаковые или похожие столбцы? В любом случае вы можете создать простой рабочий процесс, который запускается автоматически, когда элемент создается в "списке А". Поскольку рассматриваемый рабочий процесс относительно прост, я бы рекомендовал использовать SharePoint Designer (который является бесплатным) для его создания, поскольку вы можете легко сопоставить столбцы из двух списков. Прогулка ниже должна помочь вам начать работу.
Создать рабочий процесс - SharePoint Designer
Ответ 8
У меня была та же проблема.
После экспериментирования бит вместо
targetItem[f.InternalName] = sourceItem[f.InternalName];
Я использовал:
targetItem[childField.Title] = sourceItem[parentField.Title];
Ответ 9
Вот эквивалент Силвианса, который позволяет копировать по нескольким сайтам. Его код можно было бы изменить аналогичным образом...
param([string]$sourceWebUrl, [string]$sourceListName, [string]$destWebUrl, [string]$destListName)
$sourceWeb = get-spweb $sourceWebUrl;
$sourceList = $sourceWeb.Lists[$sourceListName];
$destWeb = get-spweb $destWebUrl;
$destList = $destWeb.Lists[$destListName];
$sourceList.Items |%{
$destItem = $destList.Items.Add();
$sourceItem = $_;
$sourceItem.Fields |%{
$f = $_;
if($f.ReadOnlyField -eq $false -and $f.InternalName -ne "Attachments" -and $sourceItem[$f.InternalName] -ne $null){
$destItem[$f.InternalName] = $sourceItem[$f.InternalName];
}
}
$destItem.Update();
}
Чтобы использовать, скопировать и прочесть в файл copy-listitems.ps1 и запустить с помощью командной строки Sharpoint powerhsell...
Ответ 10
Как скопировать поле и сохранить версии:
public static SPListItem CopyItem(SPListItem sourceItem, SPList destinationList)
{
SPListItem targetItem = destinationList.AddItem();
//loop over the soureitem, restore it
for (int i = sourceItem.Versions.Count - 1; i >= 0; i--)
{
//set the values into the archive
foreach (SPField sourceField in sourceItem.Fields)
{
SPListItemVersion version = sourceItem.Versions[i];
if ((!sourceField.ReadOnlyField) && (sourceField.InternalName != "Attachments"))
{
SetFields(targetItem, sourceField, version);
}
}
//update the archive item and
//loop over the the next version
targetItem.Update();
}
foreach (string fileName in sourceItem.Attachments)
{
SPFile file = sourceItem.ParentList.ParentWeb.GetFile(sourceItem.Attachments.UrlPrefix + fileName);
targetItem.Attachments.Add(fileName, file.OpenBinary());
}
targetItem.SystemUpdate();
return targetItem;
}
private static bool SetFields(SPListItem targetItem, SPField sourceField, SPListItemVersion version)
{
try
{
targetItem[sourceField.InternalName] = version.ListItem[sourceField.InternalName];
return true;
}
catch (System.ArgumentException)//field not filled
{
return false;
}
catch (SPException)//field not filled
{
return false;
}
}
Ответ 11
Скопировать список Элементы из одного списка или библиотеки SharePoint в другой список или библиотеку SharePoint с использованием кода на стороне сервера С#
//Itecollection - это набор данных из списка источников
public void CopyItemsFromOneListToAnotherList(SPListItemCollection itemCollection)
{
using (SPSite site = new SPSite(siteUrl))
{
using (SPWeb web = site.OpenWeb())
{
//Get destination list/library
//destListName - Destination list/library name
SPList destList = web.Lists.TryGetList(destListName);
foreach (SPListItem sourceItem in itemCollection)
{
//Add new Item to list
SPListItem destItem = destList.Items.Add();
foreach (SPField field in sourceItem.Fields)
{
if (!field.ReadOnlyField && !field.Hidden && field.InternalName != "Attachments")
{
if (destItem.Fields.ContainsField(field.InternalName))
{
//Copy item to destination library
destItem[field.InternalName] = sourceItem[field.InternalName];
}
}
}
//Update item in destination library or list
destItem.Update();
Console.WriteLine("Copied " + sourceItem["ID"] + "to destination list/library");
}
}
}
}