Diskuze: Problém s knihovnou Microsoft.Office.Interop.Excel
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 8 zpráv z 8.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Používám tu knihovnu celkem často. Nechtělo se mi dlouze pátrat, jak vytvářet nový soubor, tak jsem si udělal "šablonu" (jen uložený prázdný sešit) a ten otevírám takto
//otevřít excel
Microsoft.Office.Interop.Excel.Application app = new Microsoft.Office.Interop.Excel.Application();
Microsoft.Office.Interop.Excel.Workbook wb = app.Workbooks.Open(System.IO.Path.Combine(cesta + "Prazdny.xls"));
Microsoft.Office.Interop.Excel.Worksheet sheet = wb.Worksheets[1];
sheet.Range["A1"].Value = "Linka";
sheet.Range["B1"].Value = "Budova";
sheet.Range["C1"].Value = "Název";
do dalších řádků a buněk data z DB a funguje to bez problémů...
Zapomněl jsem dodat, že ten export pouštím pomocí Backgroundworkeru v jiném vlákně...
Ahoj ,
1/ Zkus pridat knihovnu interopp, jak je na obrazku
2/ spustit priklad kodu
Me to funguje bez problemu
Good Luck
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Microsoft.Office.Interop.Excel;
using _Excel = Microsoft.Office.Interop.Excel;
namespace interoppcons
{
class Program
{
static void Main(string[] args)
{
Microsoft.Office.Interop.Excel.Application excelApp = new Microsoft.Office.Interop.Excel.Application();
excelApp.Visible = true;
Microsoft.Office.Interop.Excel.Workbook excelWorkBook = excelApp.Workbooks.Add(Type.Missing);
Microsoft.Office.Interop.Excel.Worksheet xlWorksheet = excelWorkBook.Sheets[1];
Microsoft.Office.Interop.Excel.Range xlRange = xlWorksheet.UsedRange;
Když jsem přidal referenci, tak mi to stále nefunguje, tentokrát to vyhazuje tuto chybu
*System.Runtime.InteropServices.COMException: 'Microsoft Excel cannot open or save any more documents because there is not enough available memory or disk space. *
Místa na disku mám však dost
Tezko rict presne co by to mohlo byt jedno z moznych reseni muze byt toto:
napred checknul bych excel jako tady
popr toto:
https://www.codeproject.com/…-app-using-c
Kazdopadne drzim palce
Vím že to není odpověd na otázku, ale neodpustím si napsání jednoho poznatku z praxe:
Pokud nemáš hodně drobrej důvod k používání Office Interopt, tak to nedělej. Pokud jen potřebuješ jen vygenerovat sešit Excelu, existují lepší metody.
Proč nepoužívat Office Interopt?
Pro tyhle účely se mi osvědčila knihovna ClosedXML. Její použití je fakt snadný.
zkusil jsem googlit, jelikoz nemam MS Office na kompu a pridavam do hry svou
kristalovou kouli
1. problem je v pravech na slozku, kam si Excel zapisuje autosave soubory
2. problem je v tom, ze Ecel pracuje ve vice vlaknech a je potreba pockat, "nez se vzpamatuje"
....
Microsoft.Office.Interop.Excel.Application excelApp = new Microsoft.Office.Interop.Excel.Application();
excelApp.Visible = false;
bool skonci=false;
for(int i=0;(i<10) && (skonci==false);i++)
{
try
{
Microsoft.Office.Interop.Excel.Workbook excelWorkBook = excelApp.Workbooks.Add(Type.Missing);
skonci=true;
}
catch(System.Runtime.InteropServices.COMException e)
{
System.Threading.Thread.Sleep(500);
}
}
Microsoft.Office.Interop.Excel.Worksheet xlWorksheet = excelWorkBook.Sheets[1];
Microsoft.Office.Interop.Excel.Range xlRange = xlWorksheet.UsedRange;
....
Zobrazeno 8 zpráv z 8.