?
Solved

Exporting the Crystal Report XI R2 using C#

Posted on 2009-05-07
2
Medium Priority
?
580 Views
Last Modified: 2013-12-17
Hi,

I am creating a new program to generate and export the Crystal report as xls using C#. I have created a rpt file using CR binding to xsd.  The requirement is the rpt and the xsd should not be included in the solution. During the runtime, I am loading the rpt file and assigning hte dataset. But I am getting the error Logon Failed during the time of export
The Error is in the line ExportReport.Export.ObjRpt.Export

Please advise
public void Load()
        {
            string ConnectionDetails = GetConfigSetting("Connection");
             ReportDocument _CrystalReport;
            _CrystalReport = new ReportDocument();
 
            _CrystalReport.Load(@"C:\\Report1.rpt");
 
            SqlConnection Connection = new SqlConnection(ConnectionDetails);
            SqlCommand Command = new SqlCommand("GetDATA", Connection);
            Command.CommandType = CommandType.StoredProcedure;
 
	    SqlDataAdapter dsDA = new SqlDataAdapter(Command);
            DataSet dsReport = new DataSet();
            
            try
            {
                dsDA.Fill(dsReport);
                _CrystalReport.SetDataSource(dsReport);
                
            }
            catch (Exception Ex)
            {
                Console.WriteLine("Exception ocurred in LoadData \n {0}", Ex.Message.ToString());
            }
 
       
                    try
            {
            ExportReport rptExp = new ExportReport("xls", "C:", "test");
 
            rptExp.Report = _CrystalReport;
 
            string _exportedFile = rptExp.Export();
            Console.WriteLine("File [{0}] successfully exported", _exportedFile);
        }
        catch (Exception Ex)
        {
 
            Console.WriteLine("Exception ocurred in LoadData \n {0}", Ex.Message.ToString());
 
        }
 
	ExportReport.cs
	---------------
 
	 private void ConfigureExportToXls()
        {
            objExportOpt.ExportFormatType = ExportFormatType.Excel;
 
            ExcelFormatOptions objExcelOptions = new ExcelFormatOptions();
            objExcelOptions.ExcelTabHasColumnHeadings = true;
            objExcelOptions.ShowGridLines = true;
            objExcelOptions.ExcelUseConstantColumnWidth = false;
            objExportOpt.ExportFormatOptions = objExcelOptions;
            objdiskDest.DiskFileName = exportPath +  expfileName + ".xls"; ;
            objExportOpt.DestinationOptions = objdiskDest;
        }
	 public string Export()
        {
            //try
            {
                ExportSetup();
                ExportSelection();
                exportedfile = objdiskDest.DiskFileName.ToString();
                objRpt.Export();
                return exportedfile;
            }
 
        }
private void ExportSelection()
        {
            switch (expFormat)
            {
                case "rpt"://  ExportFormatType.CrystalReport
                    ConfigureExportToRpt();
                    break;
                case "rtf"://ExportFormatType.RichText
                    ConfigureExportToRtf();
                    break;
                case "wrd": //ExportFormatType.WordForWindows
                    ConfigureExportToDoc();
                    break;
                case "xls": //ExportFormatType.Excel:
                    ConfigureExportToXls();
                    break;
                case "pdf"://ExportFormatType.PortableDocFormat:
                    ConfigureExportToPdf();
                    break;
                case "html32"://ExportFormatType.HTML32:
                    ConfigureExportToHtml32();
                    break;
                case "html40"://ExportFormatType.HTML40:
                    ConfigureExportToHtml40();
                    break;
            }
        }
 
	  private void ExportSetup()
        {
 
            if (!System.IO.Directory.Exists(exportPath))
            {
                System.IO.Directory.CreateDirectory(exportPath);
            }
            objdiskDest = new DiskFileDestinationOptions();
            objExportOpt = objRpt.ExportOptions;
            objExportOpt.ExportDestinationType = ExportDestinationType.DiskFile;
            objExportOpt.FormatOptions = null;
        }

Open in new window

0
Comment
Question by:vonbalaji
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
2 Comments
 
LVL 101

Accepted Solution

by:
mlmcc earned 80 total points
ID: 24329581
0

Featured Post

Give Your Engineering Team a Productivity Boost

Learn why container technology is so powerful and how it can provide your team with productivity gains and other benefits.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Many of us here at EE write code. Many of us write exceptional code; just as many of us write exception-prone code. As we all should know, exceptions are a mechanism for handling errors which are typically out of our control. From database errors, t…
A long time ago (May 2011), I have written an article showing you how to create a DLL using Visual Studio 2005 to be hosted in SQL Server 2005. That was valid at that time and it is still valid if you are still using these versions. You can still re…
Michael from AdRem Software outlines event notifications and Automatic Corrective Actions in network monitoring. Automatic Corrective Actions are scripts, which can automatically run upon discovery of a certain undesirable condition in your network.…
Michael from AdRem Software explains how to view the most utilized and worst performing nodes in your network, by accessing the Top Charts view in NetCrunch network monitor (https://www.adremsoft.com/). Top Charts is a view in which you can set seve…
Suggested Courses

801 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question