·您现在的位置: 云翼网络 >> 文章中心 >> 网站建设 >> 网站建设开发 >> ASP.NET网站开发 >> Aspose.Words导出dt到word的问题

Aspose.Words导出dt到word的问题

作者:佚名      ASP.NET网站开发编辑:admin      更新时间:2022-07-23

已解决:单挑数据导入到一个Word文档,导出文字和图片成功,执行Main();方法导出dt到word

待解决:多条数据(文字,图片的导入到一个word文档里面)从dt导入到word;已发现的错误提示“已添加了具有相同键的项”

所用dll库下载地址:aspose.Words 和模板文件2.docx

 

以下为完整代码。执行Main()即可导出。

        PRivate void Main()
        {
            var dic = new Dictionary<string, string>();
            Document doc = new Document(Server.MapPath(@"2.doc"));//模板文件路径
            string StrID = Request.Form["YX_CH"];//这里是获取前台GridView项目的值,穿给下面的dt作为查询条件之一,另外的nodeid是节点编号
            if (StrID == null)
            {
                WebMsgBox.Show("您还未选择任何数据!");
            }
            DataTable dt = bArticle.GetList(" nodeid='" + Request.QueryString["nodeid"] + "' and ArticleID in (" + StrID + ")").Tables[0];
            //if (dt.Rows.Count > 0)
            //{
            //    for (int i = 0; i < dt.Rows.Count; i++)
            //    {
//以上4行注释的为for循环(开始)
dic.Add("标题", dt.Rows[0]["art_title"].ToString()); //“已添加了具有相同键的项”开始的第一行,浏览器所指位置 dic.Add("日期", dt.Rows[0]["art_pubdate"].ToString()); dic.Add("图片", Server.MapPath(@"/UploadFiles/Images/") + dt.Rows[0]["art_img"].ToString()); //使用特殊字符串替换 doc = new Document(Server.MapPath(@"2.doc")); foreach (var key in dic.Keys) { if (key != "图片") { var repStr = string.Format("&{0}&", key); doc.Range.Replace(repStr, dic[key], false, false); } else { Regex reg = new Regex("&图片&"); doc.Range.Replace(reg, new ReplaceAndInsertImage(Server.MapPath(@"/UploadFiles/Images/") + dt.Rows[i]["art_img"].ToString()), false); } } // } //}
             //以上4行注释的为for循环(结束)
        doc.Save(Server.MapPath(@"2ks.doc"));//保存导出的文件 Response.End(); }
//插入图片的一个方法 public class ReplaceAndInsertImage : IReplacingCallback { /// <summary> /// 需要插入的图片路径 /// </summary> public string url { get; set; } public ReplaceAndInsertImage(string url) { this.url = url; } public ReplaceAction Replacing(ReplacingArgs e) { //获取当前节点 var node = e.MatchNode; //获取当前文档 Document doc = node.Document as Document; DocumentBuilder builder = new DocumentBuilder(doc); //将光标移动到指定节点 builder.MoveTo(node); //插入图片 builder.InsertImage(url); return ReplaceAction.Replace; } }

 精简以后的Main方法,但是还只是输出一条数据。

        private void Main()
        {
            Document doc = new Document(Server.MapPath(@"2.doc"));
            DataTable dt = bArticle.GetList(" nodeid='4'").Tables[0];        
            if (dt.Rows.Count > 0)
            {
                for (int i = 0; i < dt.Rows.Count; i++)
                {
                    doc.Range.Replace("&标题&", dt.Rows[2]["art_title"].ToString(), false, false);
                    doc.Range.Replace("&日期&", dt.Rows[i]["art_pubdate"].ToString(), false, false);
Regex reg = new Regex("&图片&"); doc.Range.Replace(reg, new ReplaceAndInsertImage(Server.MapPath(@"/UploadFiles/Images/") + dt.Rows[i]["art_img"].ToString()), false); } doc.Save(Server.MapPath(@"2ks.doc")); Response.End(); } }