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