本文介绍了如何在命令行方式下, 创建自定义列表, 将外部数据导入到列表以及生成视图.

$listname = "contact0422"
$column_text = @(
"LanID"
"显示名"
"拼音姓"
"拼音名"
"员工号"
"公司邮箱"
"公司名称"
"手机号码"
"公司电话"
"部门名称"
"岗位"
"地区"
"直属领导"
"状态"
)
Connect-SPOCSOM -Username 'abc@company.cn' -Password 'your_pwd' -Url 'https://company.sharepoint.cn/IT/'
<# 新建自定义列表 #>
New-SPOList -Title $listname -TemplateType 100
<# 新建text类型的列 #>
$column_text | ForEach {
New-SPOListColumn -ListTitle $listname -FieldDisplayName $_ -FieldType Text
}
<# 插入值 #>
# 通过Get-SPOListColumn -ListTitle $listname -FieldTitle 'LanID'(此处区分大小写)可以查看InternalName
Import-Csv -Path "C:\Users\IT\Desktop\user details template1 - 副本.csv" -Encoding Default | ForEach-Object {
$fields= @(
@{"fieldname"="LanID";"fieldvalue"=$_.Lanid},
@{"fieldname"="_x663e__x793a__x540d_";"fieldvalue"=$_.显示名},
@{"fieldname"="_x62fc__x97f3__x59d3_";"fieldvalue"=$_.拼音姓},
@{"fieldname"="_x62fc__x97f3__x540d_";"fieldvalue"=$_.拼音名},
@{"fieldname"="_x5458__x5de5__x53f7_";"fieldvalue"=$_.员工号},
@{"fieldname"="_x516c__x53f8__x90ae__x7bb1_";"fieldvalue"=$_.公司邮箱},
@{"fieldname"="_x516c__x53f8__x540d__x79f0_";"fieldvalue"=$_.公司名称},
@{"fieldname"="_x624b__x673a__x53f7__x7801_";"fieldvalue"=$_.手机号码},
@{"fieldname"="_x516c__x53f8__x7535__x8bdd_";"fieldvalue"=$_.公司电话},
@{"fieldname"="_x90e8__x95e8__x540d__x79f0_";"fieldvalue"=$_.部门名称},
@{"fieldname"="_x5c97__x4f4d_";"fieldvalue"=$_.岗位},
@{"fieldname"="_x5730__x533a_";"fieldvalue"=$_.地区},
@{"fieldname"="_x76f4__x5c5e__x9886__x5bfc_";"fieldvalue"=$_.直属领导},
@{"fieldname"="_x72b6__x6001_";"fieldvalue"=$_.状态}
)
New-SPOListItem -ListTitle $listname -ItemTitle $_.员工号 -AdditionalMultipleFields $fields
}

2016-4-25更新:

$listname = "contact0425"
Connect-SPOCSOM -Username 'abc@xyz.cn' -Password 'your_pwd' -Url 'https://company.sharepoint.cn/IT/'
$listnames = Get-SPOList
$column_text = @(
"LanID"
"显示名"
"拼音姓"
"拼音名"
"员工号"
"公司邮箱"
"公司名称"
"手机号码"
"公司电话"
"部门名称"
"岗位"
"地区"
"直属领导"
"状态"
)
if ($listname -in $listnames.title) { Write-Host "$listname is already exist in Sharepoint!!!" }
else {
# 新建自定义列表
New-SPOList -Title $listname -TemplateType 100
# 新建text类型的列
$column_text | ForEach {
New-SPOListColumn -ListTitle $listname -FieldDisplayName $_ -FieldType Text
}}
# 通过Get-SPOListColumn -ListTitle $listname -FieldTitle 'LanID'(此处区分大小写)可以查看InternalName
# 由于中文的关系, internalname会被转成utf8编码,所以这里构建title和internalname之间的哈希表
# 避免了类似这样的代码@{"fieldname"="_x663e__x793a__x540d_";"fieldvalue"=$_.显示名}, 增强了可读性
$ht = $column_text | ForEach {
Get-SPOListColumn -ListTitle $listname -FieldTitle $_
} | Select title, internalname | foreach { @{$_.title = $_.internalname} }
# 插入值
Import-Csv -Path "C:\Users\IT\Desktop\user details template1 - 副本.csv" -Encoding Default | ForEach-Object {
# 下面最外层的@()不是哈希表,而是New-SPOListItem的特性
$fields= @(
@{"fieldname"=$ht.Lanid;"fieldvalue"=$_.Lanid},
@{"fieldname"=$ht.显示名;"fieldvalue"=$_.显示名},
@{"fieldname"=$ht.拼音姓;"fieldvalue"=$_.拼音姓},
@{"fieldname"=$ht.拼音名;"fieldvalue"=$_.拼音名},
@{"fieldname"=$ht.员工号;"fieldvalue"=$_.员工号},
@{"fieldname"=$ht.公司邮箱;"fieldvalue"=$_.公司邮箱},
@{"fieldname"=$ht.公司名称;"fieldvalue"=$_.公司名称},
@{"fieldname"=$ht.手机号码;"fieldvalue"=$_.手机号码},
@{"fieldname"=$ht.公司电话;"fieldvalue"=$_.公司电话},
@{"fieldname"=$ht.部门名称;"fieldvalue"=$_.部门名称},
@{"fieldname"=$ht.岗位;"fieldvalue"=$_.岗位},
@{"fieldname"=$ht.地区;"fieldvalue"=$_.地区},
@{"fieldname"=$ht.直属领导;"fieldvalue"=$_.直属领导},
@{"fieldname"=$ht.状态;"fieldvalue"=$_.状态}
)
New-SPOListItem -ListTitle $listname -ItemTitle $_.员工号 -AdditionalMultipleFields $fields
}

创建视图:

$listname = "contact0412"
Connect-SPOCSOM -Username 'your_id' -Password 'your_pwd' -Url 'https://company.sharepoint.cn/IT/'
$view1_fields=@(
"工号"
"姓名"
"籍贯城市"
)
New-SPOListView -ListName $listname -ViewName "view_1" -ViewFields $view1_fields

使用PowerShell向SharePoint中写入数据的更多相关文章

  1. 向post请求中写入数据,最终保存在了HttpWebRequest.Params中

    一.向post请求中写入数据,最终保存在了HttpWebRequest.Params中: 1)如果存入的是IDictionary类型的字符串变量,如:“username=administrator”, ...

  2. PHP连接sqlserver的两种方法,向sqlserver2000中写入数据,中文乱码

    项目环境是php5.3.28 项目用的ThinkPHP3.2.3  已经mysql5.5数据库,要和另一个项目对接,需要连接sqlsever2000数据库进行一些操作. 第一种用php自带扩展连接数据 ...

  3. 通过I2C总线向EEPROM中写入数据,记录开机次数

    没买板子之前,用protues画过电路图,实现了通过i2c总线向EEPROM中写入和读出数据. 今天,在自己买的板子上面写关于i2c总线的程序,有个地方忘了延时,调程序的时候很蛋疼.下面说说我对I2c ...

  4. 【转】从QDataStream向QByteArray中写入数据时的注意点(QT)

    最近发现从QDataStream向QByteArray中写入数据常常是写不进去的,通过查看QT的源码: QDataStream &operator>>(QDataStream &a ...

  5. POI往word模板中写入数据

    转: POI往word模板中写入数据 2018年03月24日 16:00:22 乄阿斗同學 阅读数:2977  版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn ...

  6. Verilog利用$fdisplay命令往文件中写入数据

    最近在做的事情是,用FPGA生成一些满足特定分布的序列.因此为了验证我生成的序列是否拥有预期的性质,我需要将生成的数据提取出来并且放到MATLAB中做数据分析. 但是网上的程序很乱,表示看不懂==其实 ...

  7. 复制excel表,往excel表中写入数据

    import java.io.FileInputStream;import java.io.FileOutputStream;import java.io.IOException;import jav ...

  8. POI向Excel中写入数据及追加数据

    import org.apache.poi.xssf.usermodel.XSSFCell; import org.apache.poi.xssf.usermodel.XSSFRow; import ...

  9. 计算机二级-C语言-程序填空题-190117记录-对文件的处理,复制两个文件,往新文件中写入数据。

    //给定程序的功能是,调用函数fun将指定源文件中的内容赋值到指定目标文件中,复制成功时函数返回1,失败时返回0,把复制的内容输出到终端屏幕.主函数中源文件名放在变量sfname中,目标文件名放在变量 ...

随机推荐

  1. XAML Region标签功能

    XAML本身没有Region标签功能,很郁闷.现在有插件可以实现该功能了!   <!-- Region (Any Text You Want) --> Your Code <!-- ...

  2. Python安装pandas

    http://blog.sina.com.cn/s/blog_a73687bc0101eenc.html 安装vcforpython: http://www.microsoft.com/en-us/d ...

  3. 斑点检测(LoG,DoG)(下)

    斑点检测(LoG,DoG)(下) LoG, DoG, 尺度归一化 上篇文章斑点检测(LoG,DoG)(上)介绍了基于二阶导数过零点的边缘检测方法,现在我们要探讨的是斑点检测.在边缘检测中,寻找的是二阶 ...

  4. Tomcat在局域网中localhost可以访问,但是无法通过本地ip访问,127.0.0.1也无法访问问题的解决方法

    环境:Tomcat6,Windows Server2008 R2, Tomcat使用默认端口8080. 在BO服务器上使用Tomcat6作为WEB服务器,在服务器本地使用http://localhos ...

  5. ccc 多点触控

    研究了一天,多点触控的点无法保存,只能模拟多点触控了 cc.Class({ extends: cc.Component, properties: { wheelStick:{ default:null ...

  6. BZOJ3468 : 滑雪

    根据公式$x^k=\sum_{i=1}^k Stirling2(k,i)i!C(x,i)$, 设$f[i][j][k]$表示从$(i,j)$出发的所有路径的$C(路径长度,k)$的和, 根据$C(n, ...

  7. BZOJ2646 : neerc2011 flight

    答案由$3$部分构成: $1$.抛物线的极值. $2$.询问区间的左端点在抛物线上的值. $3$.询问区间的右端点在抛物线上的值. 对于$1$,就是某个矩形范围内最大值查询,使用KD-Tree可以在$ ...

  8. My first blog!!!!!

    这是我的第一篇blog,希望以后学的知识都能够记录下来,形成记忆,方便查看和学习.如果有朋友看到我blog中的错误,欢迎批评指正,谢谢~\(≧▽≦)/~啦啦啦 以后学的知识要整理出来,方便自己的同时也 ...

  9. JS实现设为首页与加入收藏

    <script type="text/javascript"> // 设置为主页 function SetHome(obj, vrl) { try { obj.styl ...

  10. jquery插件之拖拽

    该插件乃本博客作者所写,目的在于提升作者的js能力,也给一些js菜鸟在使用插件时提供一些便利,老鸟就悠然地飞过吧. 此插件旨在实现目前较为流行的拖拽效果,您可以根据自己的实际需求来设置被拖拽元素是否可 ...