1、问题:用存储过程计算之后返回的数为int,应该为double
原因:存储过程中用return会转换成int并返回
改进:将return改为select
2、问题:导出Excel后,再从相对路径读取Template/SimpleReport.xaml会报一个找不到路径的错;如果不导出Excel直接读取Template/SimpleReport.xaml就没有问题。
原因: 当导出Excel后(选择了一个保存路径),System.Environment.CurrentDirectory会改为保存Excel的路径,所以从相对路径读取会报错。查了一下,WINDOWS-API就这么设置的
改进:用System.IO.Path.Combine(AppDomain.CurrentDomain.SetupInformation.ApplicationBase, @"Templates/SimpleReport.xaml")
C#获得各种路径方法集合


{
//获取当前进程的完整路径,包含文件名(进程名)。
//result: X:\xxx\xxx\xxx.exe (.exe文件所在的目录+.exe文件名)
string str1 = this.GetType().Assembly.Location;
//获取新的 Process 组件并将其与当前活动的进程关联的主模块的完整路径,包含文件名(进程名)。
//result: X:\xxx\xxx\xxx.exe (.exe文件所在的目录+.exe文件名)
string str2 = System.Diagnostics.Process.GetCurrentProcess().MainModule.FileName;
//获取和设置当前目录(即该进程从中启动的目录)的完全限定路径。
//result: X:\xxx\xxx (.exe文件所在的目录)
string str3 = System.Environment.CurrentDirectory;
//获取当前 Thread 的当前应用程序域的基目录,它由程序集冲突解决程序用来探测程序集。
//result: X:\xxx\xxx\ (.exe文件所在的目录+"\")
string str4 = System.AppDomain.CurrentDomain.BaseDirectory;
//获取和设置包含该应用程序的目录的名称。
//result: X:\xxx\xxx\ (.exe文件所在的目录+"\")
string str5 = System.AppDomain.CurrentDomain.SetupInformation.ApplicationBase;
//获取启动了应用程序的可执行文件的路径,不包括可执行文件的名称。
//result: X:\xxx\xxx (.exe文件所在的目录)
string str6 = System.Windows.Forms.Application.StartupPath;
//获取启动了应用程序的可执行文件的路径,包括可执行文件的名称。
//result: X:\xxx\xxx\xxx.exe (.exe文件所在的目录+.exe文件名)
string str7 = System.Windows.Forms.Application.ExecutablePath;
//获取应用程序的当前工作目录(不可靠)。
//result: X:\xxx\xxx (.exe文件所在的目录)
string str8 = System.IO.Directory.GetCurrentDirectory();
}
3、问题:WPF窗体启用定时关闭,使用this.Close()或Application.Current.Shutdown报错
原因:由于启动timer相当于开启了一个线程,所以在此线程中无法直接对主线程进行操作
改进:用异步this.Dispatcher.BeginInvokeShutdown(System.Windows.Threading.DispatcherPriority.Normal);