Excel数据导入到Sharepoint List
这个功能是从XML中读取需要导入到Sharepoint List的列名字,然后把Excel中对应的数据导入到Sharepoint List中。基本原理,把Excel中数据临时放到Datatable中,然后查看文件夹是否存在,如果要导入的文件夹已经存在,则清空当前文件夹,放到最新数据。如果没有,遍历Datatable,一次存放到导入的list中,顺便保存一份到本地。
1. 准备工具
服务器上需要安装Excel的组件AccessDatabaseEngine
http://www.microsoft.com/en-us/download/details.aspx?id=13255
2.代码
Common com = new Common();
public ImportExcelToList()
{
} private string _TelephoneList;
[Personalizable(true)]
[WebBrowsable(true)]
[WebDisplayName("Telephone List Name")]
[DefaultValue("Telephone")]
public string TelephoneList
{
set { _TelephoneList = value; }
get { return _TelephoneList; }
} protected override void OnInit(EventArgs e)
{
base.OnInit(e);
InitializeControl();
} protected void Page_Load(object sender, EventArgs e)
{
} protected void btn_upload_Click(object sender, EventArgs e)
{
try
{
if (this.upload_Excel.HasFile)
{
List<string> lis = com.getAppManager("Telephone");
string fileName = "Telephone_" + System.DateTime.Now.ToString("yyyyMMddhhmmss");
string destiation =Constants.file_TelephoneDestination + fileName + ".xlsx";
this.upload_Excel.SaveAs(destiation);
ImportExcel(lis, destiation, TelephoneList);
}
else
{
lb_error.Text = "Please choose telephone excel file to upload, in sheet which name is 'Date'.";
}
}
catch (Exception ex)
{
lb_error.Text = ex.Message;
}
} private void CreateFolderInList(string folderName, SPList list,SPWeb web)
{
try
{
//Check if the Folder is already available in the list
SPQuery query = new SPQuery();
query.Query = "<Where><And><Eq><FieldRef Name='Title'/><Value Type='Text'>" + folderName + "</Value></Eq><Eq><FieldRef Name='FSObjType'/><Value Type='Lookup'>1</Value></Eq></And></Where>";
query.ViewAttributes = "Scope=\"RecursiveAll\""; //Retrieve the items based on Query
SPListItemCollection items = list.GetItems(query); //Item count is "0" if the folder does not exist
if (items.Count == )
{
SPListItem folderItem = list.AddItem(list.RootFolder.ServerRelativeUrl, SPFileSystemObjectType.Folder);
folderItem["Title"] = folderName;
folderItem.Update();
//return folderItem.Url;
}
else
{
com.cleanListData(list, folderName,web);
}
}
catch (Exception ex)
{
lb_error.Text = ex.Message;
}
} /// <summary>
///
/// </summary>
/// <param name="l">config file</param>
/// <param name="filePath">Excel path</param>
/// <param name="listName">list name</param>
/// <param name="folder">list folder</param>
private void ImportExcel(List<string> l, string filePath, string listName)
{
DataTable dt = ExcelToDS(filePath);
string folder = dt.Rows[]["Month"].ToString();
using (SPSite spSite =new SPSite(SPContext.Current.Web.Url))
{
using (SPWeb spWeb = spSite.OpenWeb())
{
spWeb.AllowUnsafeUpdates = true;
SPList list = spWeb.Lists[listName];
CreateFolderInList(folder, list, spWeb);
foreach (DataRow row in dt.AsEnumerable())
{
//add item to list folder
SPListItem spListItem = list.Items.Add(list.RootFolder.SubFolders[folder].ServerRelativeUrl, SPFileSystemObjectType.File);
for (int i = ; i < l.Count; i++)
{
string colName = l[i];
if (colName != "All")
{
spListItem[colName] = row[i];
}
else
{ }
}
spListItem.Update();
}
spWeb.AllowUnsafeUpdates = false;
}
}
} /// <summary>
/// get datatable from sheet Data
/// </summary>
/// <param name="Path"></param>
/// <returns></returns>
public DataTable ExcelToDS(string Path)
{
DataTable dt = new DataTable();
string strConn = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + Path + ";Extended Properties=\"Excel 12.0;HDR=YES;IMEX=1\"";
/// strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + Path + ";Extended Properties='Excel 8.0;HDR=False;IMEX=1'";
SPSecurity.RunWithElevatedPrivileges(delegate()
{
OleDbConnection conn = new OleDbConnection(strConn);
try
{
if (conn.State != ConnectionState.Open)
conn.Open();
string strExcel = "select * from [Data$] where `Line` Is Not Null";
OleDbDataAdapter adapter = new OleDbDataAdapter(strExcel, conn);
adapter.Fill(dt); }
catch (Exception ex)
{
lb_error.Text = ex.Message;
}
finally
{
if (conn.State != ConnectionState.Closed)
conn.Close();
}
});
return dt;
}
Common中的方法
/// <summary>
/// Get list from xml configuration
/// </summary>
/// <param name="strListId"></param>
/// <returns></returns>
public List<string> getAppManager(string strListId)
{
List<string> FieldList = new List<string>();
XElement root = XElement.Load(Constants.xml_ImportList);
IEnumerable<XElement> address = from el in root.Elements("listId")
where (string)el.Attribute("id").Value == 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;
} public void cleanListData(SPList list, string folderName, SPWeb web)
{
SPQuery query = new SPQuery();
query.Query = string.Format(@"<Where>
</Where>
");
query.ViewAttributes = "Scope=\"Recursive\"";
if (!string.IsNullOrEmpty(folderName))
{
SPFolder folder = list.RootFolder.SubFolders[folderName];
query.Folder = folder;
}
SPListItemCollection items = list.GetItems(query);
StringBuilder sbDelete = new StringBuilder();
sbDelete.Append("<?xml version=\"1.0\" encoding=\"UTF-8\"?><Batch>");
foreach (SPListItem item in items)
{
sbDelete.Append("<Method>");
sbDelete.Append("<SetList Scope=\"Request\">" + list.ID + "</SetList>");
sbDelete.Append("<SetVar Name=\"ID\">" + Convert.ToString(item.ID) + "</SetVar>");
sbDelete.Append("<SetVar Name=\"Cmd\">Delete</SetVar>");
sbDelete.Append("</Method>");
}
sbDelete.Append("</Batch>");
web.ProcessBatchData(sbDelete.ToString());
}
XML
<?xml version="1.0" encoding="utf-8"?>
<lists>
<listId id="Telephone">
<field>Month</field>
<field>Line</field>
<field>Phone Type</field>
</listId>
</lists>
Excel数据导入到Sharepoint List的更多相关文章
- SharePoint开发 - Excel数据导入到SharePoint自定义列表(数据视图方式)
博客地址 http://blog.csdn.net/foxdave 本篇讲解一个有些新颖的SharePoint实例应用,给甲方做过项目的都有过体会,数据太多了,客户有Excel,要求实现批量导入. 效 ...
- kettle将Excel数据导入oracle
导读 Excel数据导入Oracle数据库的方法: 1.使用PL SQL 工具附带的功能,效率比较低 可参考这篇文章的介绍:http://www.2cto.com/database/201212/17 ...
- 效率最高的Excel数据导入---(c#调用SSIS Package将数据库数据导入到Excel文件中【附源代码下载】) 转
效率最高的Excel数据导入---(c#调用SSIS Package将数据库数据导入到Excel文件中[附源代码下载]) 本文目录: (一)背景 (二)数据库数据导入到Excel的方法比较 ...
- Java代码实现excel数据导入到Oracle
1.首先需要两个jar包jxl.jar,ojdbc.jar(注意版本,版本不合适会报版本错误)2.代码: Java代码 import java.io.File; import java.io.Fi ...
- 将Excel数据导入mysql数据库的几种方法
将Excel数据导入mysql数据库的几种方法 “我的面试感悟”有奖征文大赛结果揭晓! 前几天需要将Excel表格中的数据导入到mysql数据库中,在网上查了半天,研究了半天,总结出以下几种方法,下面 ...
- 如何把excel数据导入数据库
这里介绍2种把excel数据导入oracle数据库的方法. 1. 在excel中生成sql语句. 1)在数据列的右侧,第一行的任何位置输入="insert into table(xx,yyy ...
- excel 数据导入数据表
环境: Windows server 2012 rm sql server 2012 excel 数据导入数据表 INSERT INTO [dbo].[AdminUser] SELECT [Adm ...
- C#使用oledb方式将excel数据导入到datagridview后数据被截断为 255 个字符
问题描述:在使用oledb方式将excel数据导入到datagridview中,在datagridview单元格中的数据没有显示全,似乎只截取了数据源中的一段 解决方案:1.关于该问题,微软官方答案: ...
- excel数据导入到sqlserver中---------工作笔记
调用页面: using System; using System.Collections.Generic; using System.Linq; using System.Web; using Sys ...
随机推荐
- 炫!一组单元素实现的 CSS 加载进度提示效果
之前的文章个大家分享过各种类型的加载效果(Loading Effects),这里再给大家奉献一组基于单个元素实现的 CSS 加载动画集合.这些加载效果都是基于一个 DIV 元素实现的,十分强悍. 温馨 ...
- Android Fragment 解析和使用
Android Fragment的生命周期和Activity类似,实际可能会涉及到数据传递,onSaveInstanceState的状态保存,FragmentManager的管理和Transactio ...
- 第18/24周 乐观并发控制(Optimistic Concurrency)
大家好,欢迎回到性能调优培训.上个星期我通过讨论悲观并发模式拉开了第5个月培训的序幕.今天我们继续,讨论下乐观并发模式(Optimistic Concurrency). 行版本(Row Version ...
- 阅读《LEARNING HARD C#学习笔记》知识点总结与摘要系列文章索引
从发表第一篇文章到最后一篇文章,时间间隔有整整一个月,虽只有5篇文章,但每一篇文章都是我吸收<LEARNING HARD C#学习笔记>这本书的内容要点及网上各位大牛们的经验,没有半点废话 ...
- CSS魔法堂:你真的理解z-index吗?
一.前言 假如只是开发简单的弹窗效果,懂得通过z-index来调整元素间的层叠关系就够了.但要将多个弹窗间层叠关系给处理好,那么充分理解z-index背后的原理及兼容性问题就是必要的知识储备了.本文作 ...
- 网页颜色分辨测试小游戏的js化辨别及优化
相信大家都玩过一种网页游戏,通俗的可以叫颜色分辨测试游戏(这个名字对不对我也不知道,不要在意这些细节),也就是下面截图这个玩意,一看就明白:细细把玩过一段时间,作为一个一百米开外男女不分的弱视青年,每 ...
- JS的toFixed方法设置小数点位数后再进行计算,数据出错问题
这个应该算作失真,或者也不算.情况就是用了toFixed后再进行相关计算,得不到预期的结果 具体看例子 比如想动态计算百分比,保留一位小数如94.4%这样子 var blobTo = 409600; ...
- DB表的关系及EF中Fluent API的使用
现在使用多数的数据库是关系型数据库,那么表与表之间的关系就会显得尤其重要,对于数据的CRUD处理和以后数据的分析有很大的好处.下面是对于数据库中对表关系的理解以及在EF中使用Fluent API来创建 ...
- C#串口通信—传输文件测试
说明:该程序可能不具备实用性,仅测试用. 一.使用虚拟串口工具VSPD虚拟两个串口COM1和COM2 二.约定 占一个字节,代码如下: using System; using System.Colle ...
- 使用OWIN 为WebAPI 宿主 跨平台
OWIN是什么? OWIN的英文全称是Open Web Interface for .NET. 如果仅从名称上解析,可以得出这样的信息:OWIN是针对.NET平台的开放Web接口. 那Web接口是谁和 ...