C# 为什么Microsoft.Office.Interop.Excel需要完整路径名才能打开文件?

C# 为什么Microsoft.Office.Interop.Excel需要完整路径名才能打开文件?,c#,.net,excel,office-interop,C#,.net,Excel,Office Interop,我尝试在Visual Studio 2012中创建的C#应用程序中打开Excel文件的时间太长了。我最终发现,我需要提供Excel文件的完整路径名,即使它与可执行文件位于同一文件夹中。为什么呢 using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.IO; using System.Linq;

我尝试在Visual Studio 2012中创建的C#应用程序中打开Excel文件的时间太长了。我最终发现,我需要提供Excel文件的完整路径名,即使它与可执行文件位于同一文件夹中。为什么呢

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;

using Excel = Microsoft.Office.Interop.Excel;

namespace WindowsFormsApplication3
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void button1_Click(object sender, EventArgs e)
        {
            Excel.Application ExcelApp = new Excel.Application();
            try
            {
                MessageBox.Show("Current directory: " + Directory.GetCurrentDirectory());
                if (File.Exists("PLC01.xls"))
                {
                    MessageBox.Show("Target file exists.");
                }
                else
                {
                    MessageBox.Show("Target file does not exist.");
                }
                Excel.Workbook workbook = ExcelApp.Workbooks.Open(Directory.GetCurrentDirectory() + "\\PLC01.xls");

                // Excel.Workbook workbook = ExcelApp.Workbooks.Open("PLC01.xls");
                workbook.Close();
                MessageBox.Show("Book opened and closed.");
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }

        }
    }
}
这个版本有效。但是如果我注释掉对Open()的第一个调用,并取消注释第二个调用(它只给出文件名而不是完整路径),我会被告知无法找到该文件,即使出现“file exists”消息框,验证其存在。

目录。GetCurrentDirectory
-

“获取应用程序的当前工作目录”

这里的“应用程序”是您的C#可执行文件:启动的Excel应用程序实例与您的C#可执行文件不在同一上下文中运行,因此其“当前目录”不一定相同

如果您知道完整路径,只需将其传递给Excel即可-无需尝试仅传递文件名

仅供参考-
GetCurrentDirectory
可能不是查找Excel文件的最可靠的方法

目录。GetCurrentDirectory
-

“获取应用程序的当前工作目录”

这里的“应用程序”是您的C#可执行文件:启动的Excel应用程序实例与您的C#可执行文件不在同一上下文中运行,因此其“当前目录”不一定相同

如果您知道完整路径,只需将其传递给Excel即可-无需尝试仅传递文件名

仅供参考-
GetCurrentDirectory
可能不是查找Excel文件的最可靠的方法