Java Excel API - Schreiben in Excel lässt sich nicht über Makro starten

Hallo.

Ich habe folgendes Problem:
Ich möchte ein Java-Programm über ein Excel-Makro starten, welches Daten aus Excel einliest, mit diesen Daten eine Berechnung durchführt und das Ergebnis dann in ein neues Excel-File schreibt.
Das Java-Programm läuft ohne Probleme und kann aus Excel lesen und in Excel schreiben.
Wenn ich dieses Programm jedoch über ein Makro in Excel starten möchte, funktioniert lediglich das Einlesen und die Berechnung. Das Ergebnis wird nicht in ein neues Excel-File geschrieben.

Im Excel-Makro wird die bat-Datei aufgerufen, welches die jar-Datei ausführt.
Startet man den Prozess über die bat-Datei, funktioniert alles (inklusive Schreiben der neuen Excel-Datei).

Ich kann mir diesen Zusammenhang nicht erklären und würde mich über Lösungsvorschläge sehr freuen!
 
Wenn ich das Programm über die bat-Datei starte, ist Excel auch geöffnet und es funktioniert trotzdem. Aber ich hab auch schon daran gedacht und nach dem Aufruf der bat-Datei einen Befehl im Makro eingeben, der Excel schließt. Hat nichts gebracht.
In der Console steht nichts.
"(Umleiten in .txt zum testen)"...Wie ist das gemeint?
 

Empire Phoenix

Top Contributor
Dachte das du evtl keine console hast, wo du evtl fehler siehst.

Kann es sein das du safe im jxl mehrfach aufrufst? soweit ich weiß darf man das nur einmal machen kurz bevor close.
 
Solange Java rechnet, ist die cmd-Konsole geöffnet. Dort wird allerdings keine Fehlermeldung angezeigt.

Erst wird workbook.write(); und dann workbook.close(); aufgerufen, nur einmal.
Wie gesagt, startet man das Java-Programm, funktioniert auch alles, ohne Fehlermeldung.
Nur der Start der bat-Datei vom Excel-Makro geht nicht.
 

nrg

Top Contributor
Wie gesagt, startet man das Java-Programm, funktioniert auch alles, ohne Fehlermeldung.

während du die excel nebenbei offen hast ???:L. also das kann ich mir nicht vorstellen. da müsste beim schreiben eine FileNotFoundException geworfen werden..

edit: nachdem das alles checked exceptions sind, kann es auch sein, dass du sie catcht und einfach ignorierst?
 
Zuletzt bearbeitet:
Ja. Ich habe Excel geöffnet. Allerdings ist nicht das File offen, in welches geschrieben werden soll. Die catches werfen Fehlermeldungen aus und ignorieren nicht. Wie gesagt, von Java gestartet, funktioniert es auch.
 

nrg

Top Contributor
ob du excel auf hast ist ja total egal, solange du nicht die datei offen hast, in die du schreiben willst ;). also wenn du es mit dem makro machst, ist dann die excel, in die geschrieben werden soll, geöffnet?
 

nrg

Top Contributor
dann bräuchte man mal mehr informationen (code, makro, excel).

mal ne ganz andere frage: meinste die berechnung kriegste nicht in excel hin? was berechnungen betrifft, sollte da so ziemlich alles drin sein...
 
Sub java_run()
Shell ("C:\Daten\Java_Workspace\romy_ma\run_excel.bat")
Application.DisplayAlerts = False
Application.Quit
End Sub

Das ist das Makro. Die Berechnungen in Java sind schon ziemlich komplex (Evolutionärer Algorithmus). Außerdem steht das Programm ja auch schon. Es geht nur darum, dass die Daten nicht ins Excel-File geschrieben werden, wenn Java vom Makro gestartet wird. Die Berechnung (in Java) wird gestartet und auch angezeigt, aber das Ergebnis wird nicht geschrieben. Auch in cmd kommt keine Fehlermeldung.

bat-Datei: "C:\...\run_excel.jar"
 

nrg

Top Contributor
post doch bitte noch ein KSKB (workbook laden, einen wert hineinschreiben, workbook schreiben). dann könnten wir das mal testen

edit: und deine version von JExcelApi
 
Bin leider nicht eher zum Erstellen des Beispiels gekommen.
Dabei ist mir aufgefallen, dass auf einmal alles funktioniert hat. Beim Start des Makros wurde tatsächlich in ein neues Excel-File geschrieben. Als ich jedoch die Excel-Datei mit Makro geschlossen und wieder geöffnet habe, ging es nicht mehr. Durch Probieren konnte ich das Problem konkretisieren:

Das Schreiben in Excel durch Java, gestartet über ein Makro, funktioniert nur, wenn eine neue Datei gespeichert wird. Erstelle ich also noch ein Makro, welches zunächst eine neue Datei speichert, funktioniert mein Makro, das Java starten soll.

Kann sich diesen Zusammenhang jemand erklären?
 

nrg

Top Contributor
ne nicht direkt. kann vielleicht daran liegen, dass ich dich nicht ganz verstehe :).

also nochmal kurz zusammengefasst:
du hast eine Exceldatei in die geschrieben werden soll. Der geb ich jetzt einfach mal den Namen WriteTo.xls. Diese WriteTo.xls ist während des ganzen Vorgangs nicht geöffnet. Nun startest du Excel und führst ein Makro aus, dass nichts anderes macht, als eine batch-Datei zu starten. In dieser Batch-Datei lädst du die WriteTo.xls in ein Workbook, manipulierst sie und schreibst das Workbook wieder in die WriteTo.xls. Alles soweit richtig?
 
Alles richtig bis zur Batch-Datei. In der Batch-Datei wird eine Jar-Datei gestartet.
Java-Programm:
Java:
public class excel_ausgabe {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		WritableWorkbook workbook = null;
		try {
			workbook = Workbook.createWorkbook(new File("Ausgabe_excel.xls"));
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		
		 WritableSheet sheet = workbook.createSheet("Name des Sheets", 1);
		
		// Erstellen eines Zellenformats
		WritableFont fontUeberschrift = new WritableFont(WritableFont.ARIAL, 10, WritableFont.BOLD);
		WritableCellFormat formatUeberschrift = new WritableCellFormat(fontUeberschrift);// Get the current date and time from the Calendar object
		Date now = Calendar.getInstance().getTime();
		DateFormat customDateFormat = new DateFormat ("dd MMM yyyy hh:mm:ss");
		WritableCellFormat dateFormat = new WritableCellFormat (customDateFormat);
		DateTime dateCell = new DateTime(0, 1, now, dateFormat);
		
		
		// Erstellen einer Zelle
		try {
			 sheet.addCell(new Label(0, 0, "Test", formatUeberschrift));
			 sheet.addCell(dateCell); 
			
			}
		 catch (RowsExceededException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (WriteException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}

		// Daten rausschreiben
		try {
			workbook.write();
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		try {
			workbook.close();
		} catch (WriteException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}

		System.out.println("Main durchgelaufen.");
	}
}

Es wird also in Java neue eine Excel-Datei erstellt, in welcher immer das aktuelle Datum (inklusive Zeit) steht.
 
Aber es funtioniert doch. Beim Durchlaufen des Java-Programms oder beim Starten der Batch-Datei geht alles. Nur wenn das Makro angeklickt wird (welches die Batch-Datei startet), wird nur eine neue Excel-Datei erstellt, wenn in Excel gerade eine neue Datei erstellt wurde.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
Trèfle Excel-Datei nicht speicherbar, da von Java zum Bearbeiten gesperrt. Allgemeine Java-Themen 3
L Excel Datei löscht sich selbst im Programm - Java Allgemeine Java-Themen 3
ms_cikar Java Excel bearbeiten spalten werden überschrieben. Allgemeine Java-Themen 4
U Java Excel export Allgemeine Java-Themen 1
M Excel Formel in Java Allgemeine Java-Themen 7
D Mit Hilfe von Java aus Excel-Sheet Zellen in neues Excel Dokument kopieren Allgemeine Java-Themen 3
T Java Excel Drop Down Formularsteuerelement Allgemeine Java-Themen 0
R Variablen per HSSF geheime Werte von JAVA an EXCEL Allgemeine Java-Themen 2
S Java & Excel Allgemeine Java-Themen 4
C Java Excel Button Allgemeine Java-Themen 2
P java tabelle auslesen - xls (excel) fehler Allgemeine Java-Themen 5
T DLL in Java einbinden (Quelltext aus Excel VBA) Allgemeine Java-Themen 5
B Excel Datei in einem Java Programm mit GUI darstellen Allgemeine Java-Themen 9
M Rein informativ - Daten aus Excel-Tabelle in Java-Programm importieren Allgemeine Java-Themen 3
J Java-Neuling und Excel - autsch! Allgemeine Java-Themen 16
S Java Excel bestimmte Zellen auslesen (POI HSSF) Allgemeine Java-Themen 11
F Formatieren von Zellen in Excel mit Java POI Allgemeine Java-Themen 5
M JAVA und Excel Allgemeine Java-Themen 8
G Java POI HSSF Excel Datei Gruppierung und Gliederung Allgemeine Java-Themen 2
ARadauer Excel Datei in Excel aus Java heraus öffnen Allgemeine Java-Themen 10
J Java-Com Bridge für Excel Allgemeine Java-Themen 4
R excel aus meiner java-applicatin öffnen Allgemeine Java-Themen 8
E Excel Dateien mit Java lesen? Allgemeine Java-Themen 4
S Java CSV und Excel. Allgemeine Java-Themen 5
K Java <-> Excel Api Allgemeine Java-Themen 3
N Von Java aus Excel ansteuern. Allgemeine Java-Themen 4
I Java Excel API Allgemeine Java-Themen 2
C java und excel? Allgemeine Java-Themen 4
L Java & Excel & EMail Allgemeine Java-Themen 2
Z java->schnittstelle->excel Allgemeine Java-Themen 2
P Drucken einer Excel Datei in Java Allgemeine Java-Themen 8
P Excel-Datei mit Java bearbeiten Allgemeine Java-Themen 2
D Excel-Datei mit Java auslesen Allgemeine Java-Themen 1
OnDemand Java Deployment Vaadin Allgemeine Java-Themen 3
D Hat Java eine Library um JavaScript auszuwerten? Allgemeine Java-Themen 2
Zrebna Wieso sind eigentlich JUnit-Tests in src/test/java platziert - nur Konvention? Allgemeine Java-Themen 7
N LlaMA, KI, java-llama.cpp Allgemeine Java-Themen 39
V Java-Codierungsherausforderung: Navigieren durch die Macken der Datumsmanipulation Allgemeine Java-Themen 2
E Output Fehler (Java-Programm Kuchen) Allgemeine Java-Themen 11
M java: unexpected type Allgemeine Java-Themen 2
harrytut Java Input/Output Tests Junit Allgemeine Java-Themen 3
B Java Discord bot auf ein Root Server? Allgemeine Java-Themen 1
BetziTheRealOne Java PKIX path building failed as non Admin Allgemeine Java-Themen 15
D Linux, Java-Version wird nicht erkannt bzw. welche Einstellung fehlt noch? Allgemeine Java-Themen 19
KonradN Java 21 Release Allgemeine Java-Themen 5
V Umgang mit fehlenden Daten in einer Java-Datenanalyseanwendung Allgemeine Java-Themen 5
P Fehler: Hauptklasse Main konnte nicht gefunden oder geladen werden Ursache: java.lang.ClassNotFoundException: Main Allgemeine Java-Themen 24
K Java Anwendung machen Anleitung Allgemeine Java-Themen 5
G java.io.listFiles() Allgemeine Java-Themen 3
8u3631984 Frage zu Java Streams min / max Allgemeine Java-Themen 17
S Java Programm lässt sich vom USB-Stick starten, aber nicht von HDD Allgemeine Java-Themen 16
K Java-Projekt Allgemeine Java-Themen 11
K Java-Projekt Allgemeine Java-Themen 0
ruutaiokwu Welcher Browser unterstützt heutzutage noch Java Applets? Allgemeine Java-Themen 5
Jose05 Java-Klasse im extra cmd-Fenster ausführen Allgemeine Java-Themen 3
rode45e Java Threads Allgemeine Java-Themen 4
G java.io.listFiles() Allgemeine Java-Themen 2
N Java Dynamic Proxy Allgemeine Java-Themen 3
N Leichte Java Gegner Ki Allgemeine Java-Themen 10
A Java modul Problem Allgemeine Java-Themen 4
Thomasneuling Java Jar datei erstellen, von Projekt, dass auch Javafx Dateien, FXML Dateien und CSS Dateien, sowie Bilder enthält? Allgemeine Java-Themen 14
V Funktionale Schnittstelle in Java Allgemeine Java-Themen 3
OnDemand Java String in Hashmap als Key NULL Allgemeine Java-Themen 27
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
berserkerdq2 Wenn ich bei Intelij javafx mit maven importieren will, muss ich das in die pom.xml reintun, aber warum noch in module-info.java? Allgemeine Java-Themen 3
KonradN Java 20 am 21. März Allgemeine Java-Themen 1
O Java Website Stock Bot Allgemeine Java-Themen 3
J Front-/Backend in Java Allgemeine Java-Themen 14
doopexxx JAVA Google Webcrawler Allgemeine Java-Themen 1
J JavaScript innerhalb eines Java Projekts ausführen Allgemeine Java-Themen 2
A Java Programm erstellen hilfe Allgemeine Java-Themen 10
G java.lang.NoClassDefFoundError: org/aspectj/lang/Signature Allgemeine Java-Themen 2
lalex1491 Java Aktienkurse nachfragen Allgemeine Java-Themen 4
J Class to link Java Allgemeine Java-Themen 4
V Wie funktioniert das Schlüsselwort "final" von Java? Allgemeine Java-Themen 19
mrStudent Inferenz JAVA Allgemeine Java-Themen 6
U URI Rechner (Java Script) Allgemeine Java-Themen 7
TheSkyRider Java Geburtsdatum Textfeld Allgemeine Java-Themen 7
mihe7 Java 19 JavaDocs: Browserintegration Allgemeine Java-Themen 0
Encera Gleichzeitiges Ausführen und verbinden von 2 Java-Klassen über die Eingabeaufforderung und Eclipse Allgemeine Java-Themen 21
H Java Rechner Programmierung der Mathematik Allgemeine Java-Themen 33
Lennox Schinkel Java Kara Auf einen Java Host laufen lassen Allgemeine Java-Themen 17
C Fußnoten von DocX mit Java Allgemeine Java-Themen 2
C Fußnoten in DocX mit Java Allgemeine Java-Themen 1
M Aussagenlogik in Java Programmieren Allgemeine Java-Themen 22
B Per Java Word Dokument schreiben? Allgemeine Java-Themen 8
krgewb Java-Bibliothek für ONVIF Allgemeine Java-Themen 1
KonradN Oracle übergibt (Java Teile der) GraalVM Community Edition an OpenJDK Community Allgemeine Java-Themen 2
Momo16 Brauche Hilfe - Java Projekt kann nicht erstellt werden Allgemeine Java-Themen 12
B Java mit command line und jars benutzen? Allgemeine Java-Themen 18
M Java Überprüfen ob .exe-Datei bereits ausgeführt wird Allgemeine Java-Themen 2
B HTTP Allgemeine Fragen über Suchmaschine nutzen mit Java Allgemeine Java-Themen 20
Mick P. F. Wie kriege ich die Fehlermeldung "java: symbol lookup error: ..." weg? Allgemeine Java-Themen 11
K Nachhilfe Java Allgemeine Java-Themen 11
KonradN Java 19 Allgemeine Java-Themen 11
F IDEA IntelliJ Java Songliste erstellen Allgemeine Java-Themen 6
TheSepp Java bestimmtes Array auf den Wert 0 setzen Allgemeine Java-Themen 32
B Java Reflection Probleme beim wehcselseitigen Referenzieren zweier Klassen/Objekte Allgemeine Java-Themen 14
Sachinbhatt Sind alle Methoden in Java implizit virtuell Allgemeine Java-Themen 2
E Java und integrierte Grafikkarten Allgemeine Java-Themen 18

Ähnliche Java Themen

Neue Themen


Oben