4

プロジェクトでasmxWebサービスを使用しました。既存のSharePointリストにアイテムを追加したい。

   mylist.Url = Url.TrimEnd('/') + "/_vti_bin/lists.asmx";
            mylist.UseDefaultCredentials = true;
            XmlNode node = mylist.GetList(_listName);

そして、DataTableに値を保存しました。C#DatatableからSharePointリストにデータを直接追加するにはどうすればよいですか?または、それをXmlに変換して追加する必要がありますか?

ありがとうございました

4

2 に答える 2

7

アイテムの更新例しかありませんが、の一般的な使用法については、このページをご覧ください。UpdateListItems

次に、このページで、既存のアイテムを更新するのではなく、新しいアイテムを作成するために送信する必要のあるXMLの例を確認してください。

追加するアイテムごとにXML構造を構築するデータテーブルをループする必要がありますが、その後、それらすべてを1つのリクエストで追加できます。

于 2012-07-06T07:46:13.503 に答える
0

次の例は、SharePoint Webサービス、特にリストクラスを使用してリストアイテムを作成する 方法を示しています。

using System;
using System.Collections.Generic;
using System.Net;
using System.Xml;

namespace SharePoint.Client
{
    public class ListsClient : IDisposable
    {
        public ListsClient(Uri webUri, ICredentials credentials)
        {
            _client = new Lists.Lists();
            _client.Credentials = credentials;
            _client.Url = webUri + "/_vti_bin/Lists.asmx";
        }

        public ListsClient(Uri webUri)
        {
            _client = new Lists.Lists();
            _client.Url = webUri + "/_vti_bin/Lists.asmx";
        }


        /// <summary>
        /// Create a List Item 
        /// </summary>
        /// <param name="listName">List Name</param>
        /// <param name="propertyValues">List Item properties</param>
        /// <returns></returns>
        public XmlNode CreateListItem(string listName,Dictionary<string,string> propertyValues)
        {
            var payload = new XmlDocument();
            var updates = payload.CreateElement("Batch");
            updates.SetAttribute("OnError", "Continue");
            var method = payload.CreateElement("Method");
            method.SetAttribute("ID", "1");
            method.SetAttribute("Cmd", "New");
            foreach (var propertyValue in propertyValues)
            {
                var field = payload.CreateElement("Field");
                field.SetAttribute("Name", propertyValue.Key);
                field.InnerText = propertyValue.Value;
                method.AppendChild(field);
            }
            updates.AppendChild(method);
            return _client.UpdateListItems(listName, updates);
        }



        public void Dispose()
        {
            _client.Dispose();
            GC.SuppressFinalize(this);
        }


        protected Lists.Lists _client;  //SharePoint Web Services Lists proxy

    }
}

使用法

タスクアイテムを作成する方法:

using (var client = new SPOListsClient(webUrl, userName, password))
{
    var taskProperties = new Dictionary<string, string>();
    taskProperties["Title"] = "Order approval";
    taskProperties["Priority"] = "(2) Normal";
    var result = client.CreateListItem(listTitle, taskProperties);    
}

参考文献

于 2014-12-29T12:40:04.303 に答える