Почему Microsoft.Office.Interop.Excel требуется полный путь для открытия файла? - PullRequest
0 голосов
/ 07 октября 2019

Я слишком долго пытался открыть файл Excel в приложении C #, созданном в Visual Studio 2012. Наконец, я обнаружил, что мне нужно указать полный путь к файлу 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 () и раскомментирую второй, который дает только имя файла, а не полный путь, мне сообщают, что файл не может быть найден, даже если окно сообщения «Файл существует»появляется, подтверждая его существование.

1 Ответ

2 голосов
/ 08 октября 2019

https://docs.microsoft.com/en-us/dotnet/api/system.io.directory.getcurrentdirectory?view=netframework-4.8

Directory.GetCurrentDirectory -

"Получает текущий рабочий каталог приложения"

"Приложение" здесьваш исполняемый файл C #: запущенный экземпляр приложения Excel не работает в том же контексте, что и ваш исполняемый файл C #, поэтому его «текущий каталог» не обязательно совпадает.

Если вы знаете полный путь, просто передайте его в Excel - не нужно пытаться передавать только имя файла.

FYI - GetCurrentDirectory, возможно, не самый надежный способ найтиваш файл Excel

Как узнать путь к приложению в консольном приложении .NET?

...