如何在 C# 中将数据导出到 iif 文件?感谢!
问问题
2687 次
2 回答
1
public StringBuilder GetExportDataForQB(int content, DateTime startDate, DateTime endDate, int[] QBData, string accNum, string accName)
{
IJobRepository jobRepo = new JobRepository(conn);
ICustomerRepository cusRepo = new CustomerRepository(conn);
IUserRepository userRepo = new UserRepository(conn);
IProductRepository proRepo = new ProductRepository(conn);
IInvoiceRepository invoiceRepo = new InvoiceRepository(conn);
IJobProductRepository jobProductRepo = new JobProductRepository(conn);
IAccountRepository accRepo = new AccountRepository(conn);
StringBuilder sb = new StringBuilder();
switch (content)
{
case 1:
{
#region CustomerData
if (QBData[0] == 1)
{
sb.Append(GetHeader(3));
List<Customer> cusList = cusRepo.RetriveAll().ToList();
string[][] CusData = new string[cusList.Count][];
int i = 0;
foreach (Customer cus in cusList)
{
string[] CustomerData = new string[32];
CustomerData[0] = "CUST";
CustomerData[1] = cus.Name;
CustomerData[2] = cus.Street;
CustomerData[3] = cus.Surburb + cus.State + cus.AreaCode;
CustomerData[4] = cus.Country;
CustomerData[5] = "";
CustomerData[6] = "";
CustomerData[7] = "";
CustomerData[8] = "";
CustomerData[9] = "";
CustomerData[10] = "";
CustomerData[11] = "";
CustomerData[12] = cus.Phone;
CustomerData[13] = cus.Mobile;
CustomerData[14] = "";
CustomerData[15] = "";
CustomerData[16] = "";
CustomerData[17] = cus.Name;
CustomerData[18] = "";
CustomerData[19] = "";
CustomerData[20] = "";
CustomerData[21] = "N";
CustomerData[22] = "";
CustomerData[23] = "";
CustomerData[24] = "";
CustomerData[25] = "";
CustomerData[26] = "";
CustomerData[27] = "";
CustomerData[28] = cus.Name;
CustomerData[29] = cus.Name;
CustomerData[30] = "";
CustomerData[31] = "";
CusData[i] = CustomerData;
i++;
}
sb.Append(GenerateStringBuilderForQB(CusData));
}
#endregion
#region ProductData
if (QBData[2] == 1)
{
List<Product> LstProduct = proRepo.RetriveAll().ToList();
int tempForProducts = 0;
sb.Append(GetHeader(2));
string[][] ProductData = new string[LstProduct.Count][];
foreach (Product Pro in LstProduct)
{
Pro.Accnt = accRepo.GetAccountByProductID(Pro.ProductID);
string[] SingleProductData = new string[17];
SingleProductData[0] = "INVITEM";
SingleProductData[1] = Pro.Name;
SingleProductData[2] = "SERV";
SingleProductData[3] = Pro.Description;
SingleProductData[4] = "";
SingleProductData[5] = Pro.Accnt.Name;
SingleProductData[6] = "";
SingleProductData[7] = "";
SingleProductData[8] = Pro.Rate.ToString();
SingleProductData[9] = "";
SingleProductData[10] = "N";
SingleProductData[11] = "";
SingleProductData[12] = "";
SingleProductData[13] = "";
SingleProductData[14] = "";
SingleProductData[15] = "";
SingleProductData[16] = "";
ProductData[tempForProducts] = SingleProductData;
tempForProducts++;
}
sb.Append(GenerateStringBuilderForQB(ProductData));
}
#endregion
#region Transaction Data
if (QBData[3] == 1)
{
sb.Append(GetHeader(1));
List<Account> accountList = accRepo.RetriveAll().ToList();
string[][] Accounts = new string[accountList.Count][];
int tempForAcc = 0;
foreach (Account acc in accountList)
{
string[] AccData = new string[6];
AccData[0] = "ACCNT";
AccData[1] = acc.Name;
AccData[2] = acc.AccType.Name;
AccData[3] = acc.description;
AccData[4] = accName;
Accounts[tempForAcc] = AccData;
tempForAcc++;
}
sb.Append(GenerateStringBuilderForQB(Accounts));
sb.Append(GetHeader(4));
List<Invoice> PaidInvoiceList = invoiceRepo.GetPaidInvoiceList(startDate, endDate);
foreach (Invoice Inv in PaidInvoiceList)
{
Inv.Job = jobRepo.getJobByInvoiceID(Inv.InvoiceID);
string[] Transaction = new string[18];
Transaction[0] = "TRNS";
Transaction[1] = "";
Transaction[2] = "INVOICE";
Transaction[3] = string.Format("{0:M/d/yyyy}", Inv.IssueTime);
Transaction[4] = accName;
Transaction[5] = Inv.Customer.Name;
Transaction[6] = "";
Transaction[7] = Inv.Amount.ToString();
Transaction[8] = "";
Transaction[9] = Inv.Job.Desciption;
Transaction[10] = "";
Transaction[11] = "";
Transaction[12] = "N";
Transaction[13] = "";
Transaction[14] = "";
Transaction[15] = "";
Transaction[16] = "";
Transaction[17] = "";
sb.Append(GenerateStringBuilderForQB((new string[1][] { Transaction })));
List<JobProduct> JobProductList = jobProductRepo.GetJobProductListByInvoiceID(Inv.InvoiceID);
foreach (JobProduct JP in JobProductList)
{
JP.Product = proRepo.GetByID(JP.Product.ProductID);
string[] SPL = new string[18];
SPL[0] = "SPL";
SPL[1] = "";
SPL[2] = "INVOICE";
SPL[3] = string.Format("{0:M/d/yyyy}", Inv.IssueTime);
SPL[4] = JP.Product.Accnt.Name;
SPL[5] = "";
SPL[6] = "";
SPL[7] = "-" + JP.Total.ToString();
SPL[8] = "";
SPL[9] = JP.Product.Description;
SPL[10] = "";
SPL[11] = "";
SPL[12] = JP.Total.ToString();
SPL[13] = JP.Product.Description;
SPL[14] = "N";
SPL[15] = "";
SPL[16] = "";
SPL[17] = "";
sb.Append(GenerateStringBuilderForQB((new string[1][] { SPL })));
}
sb.Append("ENDTRNS" + System.Environment.NewLine);
}
}
#endregion
break;
}
}
return sb;
}
于 2011-10-26T05:11:28.437 回答
0
尽管 IIF 文件格式仍列在 QuickBooks 的用户文档中,但 Intuit 多年来一直建议开发人员不要使用 IIF 格式。如果您想忽略此建议并导出到 IIF 文件,则必须在获取数据后编写自己的格式化例程,使用QuickBooks SDK或第三方解决方案,如QODBC或rss bus。
于 2011-09-01T22:48:33.270 回答