惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

S
Schneier on Security
有赞技术团队
有赞技术团队
T
The Blog of Author Tim Ferriss
F
Fortinet All Blogs
D
DataBreaches.Net
F
Full Disclosure
腾讯CDC
博客园 - 【当耐特】
MyScale Blog
MyScale Blog
Stack Overflow Blog
Stack Overflow Blog
小众软件
小众软件
Hugging Face - Blog
Hugging Face - Blog
Last Week in AI
Last Week in AI
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
爱范儿
爱范儿
The GitHub Blog
The GitHub Blog
Engineering at Meta
Engineering at Meta
大猫的无限游戏
大猫的无限游戏
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
S
SegmentFault 最新的问题
The Register - Security
The Register - Security
WordPress大学
WordPress大学
博客园 - 聂微东
雷峰网
雷峰网
J
Java Code Geeks
Exploit-DB.com RSS Feed
Exploit-DB.com RSS Feed
P
Privacy International News Feed
酷 壳 – CoolShell
酷 壳 – CoolShell
A
Arctic Wolf
Scott Helme
Scott Helme
C
Cyber Attacks, Cyber Crime and Cyber Security
T
Tor Project blog
博客园 - 三生石上(FineUI控件)
Know Your Adversary
Know Your Adversary
AWS News Blog
AWS News Blog
G
Google Developers Blog
www.infosecurity-magazine.com
www.infosecurity-magazine.com
C
CERT Recently Published Vulnerability Notes
O
OpenAI News
Project Zero
Project Zero
K
KPMG report finds enterprise disconnect between AI and its ROI | CIO
Application and Cybersecurity Blog
Application and Cybersecurity Blog
云风的 BLOG
云风的 BLOG
N
News and Events Feed by Topic
MongoDB | Blog
MongoDB | Blog
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
Microsoft Security Blog
Microsoft Security Blog
Cisco Talos Blog
Cisco Talos Blog
P
Palo Alto Networks Blog
Schneier on Security
Schneier on Security

博客园 - 思然

邮件带图片附件 - 思然 - 博客园 XML查找节点 - 思然 - 博客园 图片处理 - 思然 - 博客园 数据绑定及其他 - 思然 - 博客园 图片上传及网络相册功能 SQL Server 2005 Express 使用心得 - 思然 附加进程调试和存储过程调试 (转)DIV CSS布局教程:应用ul、li实现表格形式 用户控件的使用经验 缓存之缓存文件依赖及编程方式设置输出缓存过期 防刷新多次提交 枚举的应用 添加div符号注意符号问题 Datalist调用本地文件绑定图片 用户控件-TreeView的用法 关于table控件的一个疑难问题(涉及循环) 关于javascript调用webservices的中文参数乱码的问题 服务器端和客户端清除TextBox控件的值 获取母版页的控件的方法
动态生成rdlc 报表(原创)
思然 · 2009-03-18 · via 博客园 - 思然

因为公司需求 研究微软的Reportviewer 因为有许多特别要求所以动态调用 比较灵活

我的需求是 根据数据不同的合并表头 (参考了随心所欲的博客文档 再次表示感谢)


 string cCount = "";
    
string dCount = "";
    
string jCount = "";
    
    
protected void Page_Load(object sender, EventArgs e)
    {
        
if (!IsPostBack)
        {
            
string id = Request.QueryString["OrderID"== null ? "1" : Request.QueryString["OrderID"].ToString();
            SqlConnection con 
= new SqlConnection("server=CHENZQ;uid=sa;pwd=luca623;database=luca");
            SqlDataAdapter sda 
= new SqlDataAdapter("select * from view_Order where C_orderID='" + id + "'", con);
            DataSet ds 
= new DataSet();
            sda.Fill(ds);
            
            cCount 
= ds.Tables[0].Rows[0]["C_CTime"].ToString();
            dCount 
= ds.Tables[0].Rows[0]["C_TTime"].ToString();
            jCount 
= ds.Tables[0].Rows[0]["C_DTime"].ToString();

           //这段代码是最重要
            ReportViewer1.Reset();
this.ReportViewer1.LocalReport.LoadReportDefinition(GenerateRdlc());
            ReportViewer1.LocalReport.DataSources.Clear();

          //Orders_DataTable1 数据源名字必须和此报表原绑定的数据源名相同
            
this.ReportViewer1.LocalReport.DataSources.Add(new ReportDataSource("Orders_DataTable1", ds.Tables[0]));this.ReportViewer1.LocalReport.Refresh();
        }
      
    }
   //这个方法就是自定义报表的样式
    
public MemoryStream GenerateRdlc()
    {
        XmlDocument sourceDoc 
= new XmlDocument();string path = AppDomain.CurrentDomain.BaseDirectory + "Orders.rdlc";
        
//c_CTime = ds.Tables[0].Rows[0]["C_CTime"].ToString();

      

        sourceDoc.Load(path);
        //下面就是xml操作了 没必要看我的 根据自己的需求而做
        XmlNode xHeader 

= sourceDoc.ChildNodes.Item(1).ChildNodes.Item(13).ChildNodes.Item(1).ChildNodes.Item(0).ChildNodes.Item(4);
        XmlNode xCells 
= xHeader.ChildNodes.Item(0).ChildNodes.Item(0).ChildNodes.Item(0);
       
//建设期
        XmlNode xmlCell = xCells.ChildNodes.Item(1);
        XmlElement xeCol 
= sourceDoc.CreateElement("ColSpan");
        xeCol.InnerText 
= cCount;
        xeCol.InnerXml 
= cCount;
        xmlCell.InnerXml 
+= xeCol.OuterXml;
        XmlNode xmlCellValue 
= xmlCell.ChildNodes.Item(0).ChildNodes.Item(0).ChildNodes.Item(4);
        xmlCellValue.InnerXml 
= "建设期";
        xmlCellValue.InnerText 
= "建设期";
        XmlNode xnRemove;
        
for (int i = 0; i <int.Parse(cCount) - 1; i++)
        {

            xnRemove 

= xCells.ChildNodes.Item(2);
            xCells.RemoveChild(xnRemove);
        }
        
//投产期
        XmlNode xmlCellT = xCells.ChildNodes.Item(2);
        XmlElement xeColT 
= sourceDoc.CreateElement("ColSpan");
        xeColT.InnerText 
= dCount;
        xeColT.InnerXml 
= dCount;
        xmlCellT.InnerXml 
+= xeColT.OuterXml;

        XmlNode xmlCellValueT 

= xmlCellT.ChildNodes.Item(0).ChildNodes.Item(0).ChildNodes.Item(4);
        xmlCellValueT.InnerXml 
= "投产期";
        xmlCellValueT.InnerText 
= "投产期";
        
for (int j = 0; j < int.Parse(dCount) - 1; j++)
        {

            xnRemove 

= xCells.ChildNodes.Item(3);
            xCells.RemoveChild(xnRemove);

        }

//生产期
        XmlNode xmlCellC = xCells.ChildNodes.Item(3);
        XmlElement xeColC 
= sourceDoc.CreateElement("ColSpan");
        xeColC.InnerText 
= jCount.ToString();
        xeColC.InnerXml 
= jCount.ToString();
        xmlCellC.InnerXml 
+= xeColC.OuterXml;

        XmlNode xmlCellValueC 

= xmlCellC.ChildNodes.Item(0).ChildNodes.Item(0).ChildNodes.Item(4);
        xmlCellValueC.InnerXml 
= "生产期";
        xmlCellValueC.InnerText 
= "生产期";
        
for (int j = 0; j < int.Parse(jCount) - 1; j++)
        {
            xnRemove 
= xCells.ChildNodes.Item(4);
            xCells.RemoveChild(xnRemove);
        }
        MemoryStream ms 
= new MemoryStream();
        XmlSerializer serializer 
= new XmlSerializer(typeof(XmlDocument));
        serializer.Serialize(ms, sourceDoc);
        ms.Position 
= 0;
        
return ms;

    }

技巧 可以先在报表里自己设计好需要的格式 用 

XmlDocument sourceDoc = new XmlDocument();

        string path = AppDomain.CurrentDomain.BaseDirectory + "Orders.rdlc";

然后用sourceDoc .save()保存生成xml 

可以看到此xml你需要改的格式是哪个地方