public MemoryStream GenerateRdlc()
          {
           XmlDocument sourceDoc = new XmlDocument();
           string path = AppDomain.CurrentDomain.BaseDirectory + "Test/OrderList.rdlc";
           sourceDoc.Load(path);
           Hashtable reportColumns = GetReportColumns(sourceDoc.LastChild);
           //just remove
           for (int i = 0; i < reportColumns.Count; i++)
           {
            if (!FindReportCoulmns(reportColumns[i].ToString()))
            {
             RemoveColumnFromRdlc(sourceDoc.LastChild, i);
            }
           }

           MemoryStream ms = new MemoryStream();
           XmlSerializer serializer = new XmlSerializer(typeof(XmlDocument));
           serializer.Serialize(ms, sourceDoc);
           ms.Position = 0;
           return ms;
          }
            至于如何GetReportColumns和RemoveColumnFromRdlc,那就很簡單了,就是一個操作xml對象的過程。比方說:
          private Hashtable GetReportColumns(XmlNode root)
          {
           Hashtable cols = new Hashtable();
           //XmlNamespaceManager s=new XmlNamespaceManager(
            XmlNode cells = FindChildNode(root,"Body/ReportItems/Table/Header/TableRows/TableRow/TableCells");
           for (int i = 0; i < cells.ChildNodes.Count; i++)
           {
            XmlNode cell =FindChildNode( cells.ChildNodes[i],"ReportItems/Textbox/DataElementName");
            cols[i] = cell.InnerText;
           }
           return cols;
          }
            這是使用這一段的代碼:
          this.ReportViewer1.LocalReport.LoadReportDefinition(this.Report.GenerateRdlc());
          this.ReportViewer1.LocalReport.DataSources.Add(new ReportDataSource("DataSet1", result.Tables[0]));
          this.ReportViewer1.LocalReport.Refresh();
            這個方法終于成功了。

            附:rdlc文件的xml一段結構

            xml結構
          1<?xml version="1.0" encoding="utf-8"?>
          2<Report xmlns="http://schemas.microsoft.com/sqlserver/reporting/2005/01/reportdefinition" xmlns:rd="http://schemas.microsoft.com/SQLServer/reporting/reportdesigner">
          3 <DataSources>
          4 <DataSource Name="ConnectionString">
          5 <ConnectionProperties>
          6 <ConnectString />
          7 <DataProvider>SQL</DataProvider>
          8 </ConnectionProperties>
          9 <rd:DataSourceID>073016a7-6cb0-4e06-a6fd-f5882a039188</rd:DataSourceID>
          10 </DataSource>
          11 </DataSources>
          12 <BottomMargin>2.5cm</BottomMargin>
          13 <RightMargin>2.5cm</RightMargin>
          14 <PageWidth>21cm</PageWidth>
          15 <rd:DrawGrid>true</rd:DrawGrid>
          16 <InteractiveWidth>21cm</InteractiveWidth>
          17 <rd:GridSpacing>0.25cm</rd:GridSpacing>
          18 <rd:SnapToGrid>true</rd:SnapToGrid>
          19 <Body>
          20 <ColumnSpacing>1cm</ColumnSpacing>
          21 <ReportItems>
          22 <Chart Name="chart1">

          文章來源:http://www.cnblogs.com/wangdetian168/archive/2008/09/03/1283351.html
          posted on 2010-09-29 13:28 sanmao 閱讀(331) 評論(0)  編輯  收藏

          只有注冊用戶登錄后才能發表評論。


          網站導航:
           

          常用鏈接

          留言簿(5)

          隨筆分類

          隨筆檔案

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 田林县| 军事| 如东县| 洞头县| 顺平县| 泊头市| 都昌县| 葵青区| 来宾市| 扶余县| 康定县| 台前县| 深州市| 萍乡市| 瑞金市| 通化县| 吉林市| 呼和浩特市| 太湖县| 湖口县| 和平区| 榆林市| 东莞市| 莱州市| 湟源县| 陆河县| 寿阳县| 长顺县| 海林市| 贵南县| 拜泉县| 梓潼县| 方山县| 乐至县| 涿鹿县| 任丘市| 高尔夫| 天台县| 民权县| 尉氏县| 玉溪市|