I am automatically creating a PDF from some of our reports in a month-end process. I am running into a problem where ReportViewer.LocalReport
can't find my report. Within the project, the report files are in "(project root folder)/Reports/report.rdlc".
How do I set ReportViewer.LocalReport.ReportPath
so I can reference my report file?
I would rather not set the full path because I don't know where it would be installed when installed on the client machines.
You can store the reports in a "resources" file, and by using an Assembly reader of the given .dll / .exe where the "resource" file is embedded, can read as a streaming reference. Then set your report to the embeded stream to get the report definition.
Special note. If your report has nested sub-reports, the report will fail unless you also set in your LocalReport subreport definition another such reference to your subreport .rdlc file.
The path is always relative to your "current directory" which in most cases is exe file- change rdlc files so that they are copied to the destination folder instead of embedded in resources(usually that's how this is done). The path in your project doesn't matter.
Use the Application.StartupPath property, it always points to directory where your EXE is located:
You'll want to make sure the report gets copied to your bin\Debug\Reports folder as well so it will work in the IDE. Use xcopy /s /d in a post-build event to get the file(s) copied.
There's a bug from what I understand that is coming from Windows XP. The issue does not exhibits itself on Windows 7.
All the above answers stand, but I have a correction.
This issue exhibits itself once you use a
SaveFileDialog
which looks like changes the path of the current application. This happens when you use the current path, relative to current wokring directory which is the default for loading RDLC, iereportpath = "nameOfReport.rldc"
. If you want to refresh the report after having used the SaveFileDialog the reportviewer cannot find the path to the report file.The solution comes from Hans Passant on the post above but I would change from this
to this
Thanks Hans