如果富文本字段包含新行、粗体、斜体、格式或任何颜色,我的文档的第一行,即富文本字段的值被很好地导出(具有相同的格式,即在项目中),其余代码未在word文档中导出。但是,如果我用记事本打开导出的文件,我可以看到整个代码正在被导出,但在 word 中只有第一行可见。
我尝试在 Word 文档中导出 SharePoint 列表。我在列表项中有几个富文本字段。如果富文本字段只包含一行简单字符串,我可以在 word 文档中导出我需要的所有内容,一切正常。
strHTMLContent.Append("<table style=margin-top: 8px; border=0 frame=hsides rules=rows cellpadding=0 cellspacing=0 width=100%>".ToString());
//Looping through each list item in the list
foreach (SPListItem oListItem in collListItems)
{
count1++;
strHTMLContent.Append("<tr><td>"+count1+". "+ oListItem.GetFormattedValue("DocName_Arm") + "</td></tr>");
}
strHTMLContent.Append("</table>".ToString());
// Giving path for saving word documents
SPList word = (SPDocumentLibrary)oSiteCollection.AllWebs["My URL"].Lists["Mylist"];
SPListItem item1 = word.Items[0];
string destUrl = word.RootFolder.Url + "/" + "MyWord7" + ".doc";
// Encoding the document to UTF8 format
byte[] byteArray = Encoding.UTF8.GetBytes((strHTMLContent.ToString()));
SPFile destFile = word.RootFolder.Files.Add(destUrl, byteArray, true);`
没有错误,我得到了 Docname_Arm 的值,与列表项中的格式相同,其他代码(在描述的代码之后我有另一个 HTML 表)在 Word 文档中不起作用(仅当 Docname_Arm 有一些格式时,如果没有工作正常),但在记事本中可见
您可以使用GetFieldValueAsHtml获取富文本字段的 html 片段:
using (SPSite site = new SPSite("http://sp/sites/jerry"))
{
using (SPWeb web = site.OpenWeb())
{
var list = web.Lists.TryGetList("TestList");
var item = list.GetItemById(1);
var eventDescField = list.Fields.GetFieldByInternalName("Parameters");
var eventDesc = item[eventDescField.Id];
var eventDescText = eventDescField.GetFieldValueAsHtml(eventDesc);
SPList word = (SPDocumentLibrary)web.Lists["Jerrydoc"];
string destUrl = word.RootFolder.Url + "/" + "MyWord8" + ".doc";
// Encoding the document to UTF8 format
byte[] byteArray = Encoding.UTF8.GetBytes((eventDescText.ToString()));
SPFile destFile = word.RootFolder.Files.Add(destUrl, byteArray, true);
}
}
这是富文本字段的列表项数据,带有一些字体颜色文本的表格:
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句