Почему мой код открывает два экземпляра Microsoft Office Word?
Я использую функцию, чтобы облегчить печать в моем приложении. Вот:
public void print(string fileName, string variables, string values, string template)
{
// CREATE TEXT FILE FOR PRINTING
FileInfo fi = new FileInfo(fileName);
Object oMissing = System.Reflection.Missing.Value;
Object oTrue = true;
Object oFalse = false;
Word.Application _wordApp = new Word.Application();
Word.Document oDoc = _wordApp.Documents.Add(template);
try
{
// Check if file already exists. If yes, delete it.
if (fi.Exists)
{
fi.Delete();
}
// Create a new file
using (StreamWriter sw = fi.CreateText())
{
sw.WriteLine(variables);
sw.WriteLine(values);
}
_wordApp.Visible = true;
oDoc.MailMerge.MainDocumentType = Word.WdMailMergeMainDocType.wdFormLetters;
oDoc.MailMerge.OpenDataSource(fileName, false, false, true);
oDoc.MailMerge.Destination = Word.WdMailMergeDestination.wdSendToNewDocument;
oDoc.MailMerge.Execute(false);
oDoc.MailMerge.Application.PrintOut();
}
catch (Exception Ex)
{
MessageBox.Show(Ex.ToString());
}
finally
{
//CLEAR RESOURCES
((Word._Document)oDoc).Close(ref oFalse, ref oMissing, ref oMissing);
((Word._Application)_wordApp).Quit();
}
}
Это выглядит хорошо, так как я могу использовать Mail Merge и сделать вещи проще. Я открываю диалог открытия файла, чтобы пользователь мог выбрать template
файл, который он будет использовать для слияния. Но затем приложение открывает template
файл без каких-либо данных на Merge Fields
и затем выполняет слияние, открывая другой документ со всеми Merge Fields
заполнен.
Есть идеи, почему это происходит? Вот код для диалога открытия файла:
//CHOOSE TEMPLATE FILE
OpenFileDialog ofd = new OpenFileDialog();
ofd.Filter = "Microsoft Word Template (*.dotx)|*.dotx";
string filter = ofd.Filter;
ofd.Multiselect = false;
ofd.Title = "Open Template File";
if (ofd.ShowDialog() == DialogResult.OK)
{
if (ofd.SafeFileName == "payslip.dotx")
{
//RETREIVE VALUES
var db = new DBConnect();
string[] values = new string[20];
bool print = false;
OleDbCommand cmd = null;
OleDbDataReader dr = null;
try
{
if (db.OpenConnection() == true)
{
string query = "SELECT * FROM employee WHERE employee_ID = " + idTxtBox.Text + "";
cmd = new OleDbCommand(query, db.mycon);
dr = cmd.ExecuteReader();
while (dr.Read())
{
values[2] = (dr["employeeName"].ToString());
values[3] = (dr["withTax"].ToString());
values[4] = (dr["sss"].ToString());
values[5] = (dr["pagIbig"].ToString());
values[6] = (dr["pHealthGov"].ToString());
values[7] = (dr["pCareOff"].ToString());
values[8] = (dr["loan_sss"].ToString());
values[9] = (dr["loan_pagIbig"].ToString());
values[10] = (dr["loan_koti"].ToString());
values[11] = (dr["tardinessAbscences"].ToString());
values[12] = totalDeductionsTxtBox.Text;
values[13] = (dr["overTime"].ToString());
values[14] = (dr["leave"].ToString());
}
print = true;
}
}
catch (OleDbException ex)
{
MessageBox.Show(ex.Message);
}
finally
{
if (dr.IsClosed == false)
{
dr.Close();
}
db.CloseConnnection();
}
if (print == true)
{
// PRINTING
var p = new printClass();
p.print(@"C:\IT Box Incorporated\Payroll\payslipCSV.csv",
"date_issued,employee_name,tax,sss,pagibig,phg,pco,sssloan,pagibigloan,kotiloan,late,total,ot,leave",
"" + (DateTime.Now.Date.ToString("MMM") + " " + DateTime.Now.Date.ToString("yyyy")) + "," + values[2] + "," + values[3] + "," + values[4] + "," + values[5] + "," + values[6] + "," + values[7] + "," + values[8] + "," + values[9] + "," + values[10] + "," + values[11] + "," + values[12] + "," + values[13] + "," + values[14] + "",
ofd.FileName);
}
else
{
MessageBox.Show("Print Failed!");
}
}
else
{
MessageBox.Show("Print Failed! Wrong File!");
}
}
else
{
MessageBox.Show("Print Failed!");
}
1 ответ
В Windows 7, если у вас включен предварительный просмотр, во время открытия файла Windows попытается просмотреть документ и запустит новый процесс winword.
Отключите режим предварительного просмотра в Windows 7.