zoukankan      html  css  js  c++  java
  • SharePoint2013导入Excel到列表

    using Microsoft.SharePoint;
    using System;
    using System.Collections.Generic;
    using System.ComponentModel;
    using System.Data;
    using System.Data.OleDb;
    using System.Linq;
    using System.Web.UI.WebControls.WebParts;
    using System.Xml.Linq;
    using System.Text;
    
    namespace MySharePointProject.UploadExcelVisualWebPart
    {
        [ToolboxItemAttribute(false)]
        public partial class UploadExcelVisualWebPart : WebPart
        {
            // 仅当使用检測方法对场解决方式进行性能分析时才取消凝视下面 SecurityPermission
            // 特性。然后在代码准备进行生产时移除 SecurityPermission 特性
            // 特性。由于 SecurityPermission 特性会绕过针对您的构造函数的调用方的
            // 安全检查,不建议将它用于生产。
            // [System.Security.Permissions.SecurityPermission(System.Security.Permissions.SecurityAction.Assert, UnmanagedCode = true)]
            public UploadExcelVisualWebPart()
            {
            }
    
            protected override void OnInit(EventArgs e)
            {
                base.OnInit(e);
                InitializeControl();
            }
    
            protected void Page_Load(object sender, EventArgs e)
            {
            }
    
            protected void btnUpload_Click(object sender, EventArgs e)
            {
                //取得XML配置文件里的导入配置,第一项字符串所代表的是须要把Excel第一列导入到的SharePoint栏名
                List<string> lis = getAppManager("123");
                //把文件上传到本地
                this.ExcelFileUpload.SaveAs(@"C:a	est.xlsx");
    
                ImportExcel(lis, @"C:a	est.xlsx", "WageList", "");//  "/2014/1"
            }
            /// <summary>
            /// 从配置文件XML取得列表
            /// </summary>
            /// <param name="strListId"></param>
            /// <returns></returns>
            private List<string> getAppManager(string strListId)
            {
                List<string> FieldList = new List<string>();
                XElement root = XElement.Load(@"C:XMLFile1.xml");//XElement.Load(System.Web.HttpContext.Current.Server.MapPath("XMLFile1.xml"));
                IEnumerable<XElement> address = from el in root.Elements("listId")
                                                where (string)el.Attribute("id") == strListId
                                                select el;
                foreach (XElement el in address)
                {
                    foreach (XNode node in el.Nodes())
                    {
                        XElement nod = (XElement)node;
                        string FieldName = nod.Value;
                        FieldList.Add(FieldName);
                    }
                }
                return FieldList;
            }
            /// <summary>
            /// 
            /// </summary>
            /// <param name="l">配置列表</param>
            /// <param name="filePath">Excel 文件路径</param>
            /// <param name="listName">列表名称</param>
            /// <param name="folder">列表目录</param>
            private void ImportExcel(List<string> l, string filePath, string listName, string folder)
            {
                DataTable dt = ExcelToDS(filePath);
                SPSite spSite = SPContext.Current.Site;
    
                SPWeb spWeb = spSite.RootWeb;
    
                SPList list = spWeb.GetListFromUrl("/Lists/" + listName + "/AllItems.aspx");
                foreach (DataRow row in dt.AsEnumerable())
                {
                    //向列表中指定的目录中加入列表项
                    SPListItem spListItem = list.AddItem("/Lists/WageList" + folder, SPFileSystemObjectType.File);
                    for (int i = 0; i < l.Count; i++)
                    {
                        spListItem[spListItem.Fields[l[i]].InternalName] = row[i];
                    }
    
                    //别忘了保存
                    spListItem.Update();
                }
    
            }
            /// <summary>
            /// 传入Excel的地址,得到Sheet1的DataTable
            /// </summary>
            /// <param name="Path"></param>
            /// <returns></returns>
            public DataTable ExcelToDS(string Path)
            {
                string strConn = "Provider=Microsoft.Ace.OleDb.12.0;" + "Data Source=" + Path + ";" + "Extended Properties='Excel 12.0;HDR=Yes;IMEX=1';";
    
                OleDbConnection conn = new OleDbConnection(strConn);
                try
                {
                    DataTable dt = new DataTable();
                    if (conn.State != ConnectionState.Open)
                        conn.Open();
                    string strExcel = "select * from [Sheet1$]";
                    OleDbDataAdapter adapter = new OleDbDataAdapter(strExcel, conn);
                    adapter.Fill(dt);
                    return dt;
                }
                catch (Exception ex)
                {
                    throw new Exception(ex.Message);
                }
                finally
                {
                    if (conn.State != ConnectionState.Closed)
                        conn.Close();
                }
            }
        }
    }
    

  • 相关阅读:
    【转】 web前端基础知识-(五)jQuery
    【转】 web前端基础知识-(四)DOM
    【转】 web前端基础知识-(三)JavaScript基本操作
    【转】 web前端基础知识-(二)CSS基本操作
    【转】 web前端基础知识-(一)html基本操作
    Vue的dom更新机制 & Vue的nextTick
    VUE项目中实现PDF预览
    WebView
    Nginx服务器
    前端存储 --- cookie & localStorage & sessionStorage & Web SQL & IndexDB & Cache Storage
  • 原文地址:https://www.cnblogs.com/wzzkaifa/p/6789969.html
Copyright © 2011-2022 走看看