305 Benutzer online
24. Oktober 2025, 16:34:07

Windows Community



 Antworten / AufrufeThemen mit dem Stichwort comschnittstelle
14
Antworten
19092
Aufrufe
PDFCreator - wie unter WordVBA programmieren?
Begonnen von Jean Raul
03. Juli 2008, 22:35:12
Hat schon mal jemand versucht, mit dem (kostenlosen) PDFCreator
http://www.pdfforge.org/
WordVBA zu programmieren? Im Prinzip schaffe ich es ja mit dem mitgelieferten Beispielprogrammen. Ich habe aber Probleme damit, den Dateinamen zu programmieren, unter dem die pdf ausgegeben werden soll. Die PDF wird immer mit dem Pfad und Namen ausgegeben, der den Autosave-Optionen des Programms entspricht, aber nicht mit dem Namen, den ich im Programm vorgebe und haben will.

So lautet mein VBA-Skript. Es soll die aktuell in Word geöffnete Datei ohne weitere Benutzereingriffe als PDF in den Pfad <PDFPfad$> unter dem Namen <PDFName$> speichern:
[code]
Public Function PDFDruck(Optional OhneMsg As Boolean)
Dim Zwi$, PDFPfad$, PDFName$, pdfjob
PDFPfad$ = "C:\Zwi"
'Ermittelt den Namen des aktiven Dokuments:
Zwi$ = ActiveDocument.Name
If InStr(1, Zwi$, ".", vbTextCompare) > 1 Then
   PDFName$ = Mid(Zwi$, 1, InStr(1, Zwi$, ".", vbTextCompare) - 1)
Else
   PDFName$ = "Unbenannt"
End If

Set pdfjob = New PDFCreator.clsPDFCreator
With pdfjob
   If .cStart("/NoProcessingAtStartup") = False Then
      MsgBox "PDFCreator kann nicht initialisiert werden. Bitte beenden Sie die PDFCreator-Prozesse.", vbCritical + _
         vbOKOnly, "PrtPDFCreator"
      GoTo Ende
   End If
   .cOption("UseAutosave") = 1
   .cOption("UseAutosaveDirectory") = 1
   .cOption("AutosaveDirectory") = PDFPfad$
   .cOption("AutosaveFilename") = PDFName$
   .cOption("AutosaveFormat") = 0    '0 = PDF
   .cDefaultPrinter = "PDFCreator"
   .cPrinterStop = False
   .cClearCache
   ActiveDocument.PrintOut Background:=False
End With
'!!!!!!!!!!!!!!!!Wartet ab, bis fertig gedruckt ist:!!!!!!!!!!!!!!
Dim sleepTime, maxTime, c
sleepTime = 250
maxTime = 10
c = 0
Do While (pdfjob.cOutputFilename = "") And (c < (maxTime * 1000 / sleepTime))
  c = c + 1
  Sleep 200
Loop
'!!!!!!!!!!!!!!!Ende des Abwartens!!!!!!!!!!!!!!
Ende:
Zwi$ = pdfjob.cOutputFilename
pdfjob.cClose
Set pdfjob = Nothing
If Not OhneMsg Then
   If Len(Zwi$) > 0 Then
      MsgBox "Das Dokument wurde nach " & Zwi$ & " gespeichert.", vbInformation
   Else
      MsgBox "Beim Speichern als pdf ist ein Fehler aufgetreten!", vbCritical
   End If
End If
PDFDruck = Zwi$
End Function
[/code]

Auch die anderen COM-Funktionen des Programms sind mir ein Buch mit sieben Rätseln, da die Funktionen nach meiner Ansicht sehr schlecht dokumentiert sind. Weiß jemand mehr? Anbei die "Dokumentation" und die Beispieldateien:

5698801156988011 6257705162577051 6891193668911936 schnittstelleschnittstelle exyexy 7918900679189006 8576141685761416 9695298096952980 problemeprobleme d2kd2k 4517533845175338 6772027767720277 7403565374035653 7867747478677474 8546427685464276 9678340596783405 117218890117218890 64bit64bit bgebge 4499011044990110 5614685456146854 netnet 6172594861725948 6611102266111022 7361230573612305 7859751978597519 ansprechenansprechen 8507680985076809 win7win7 9023734690237346
3
Antworten
13685
Aufrufe
Fehlende COM Schnittstelle emulieren
Begonnen von Diesel
10. Juni 2008, 17:18:22
Hi,

ich habe folgendes Problem, dass ich einen HP Switch via Serielle Schnittstelle managen möchte.
Leider besitzt mein HP Notebook keine Serielle Schnittstelle.
Mein Chef hat mir den Tip gegeben ein Adapter (USB2Serial) zu nutzen, jedoch weiß ich nicht wie ich den konfigurieren soll.
Die Switch konfiguration verläfut via Hyperterminal bie XP, bei Vista käme da nur Telnet in Frage es sei denn ich nutze tools a la Putty/Tutty.

Klartext:
Ich muss die genutzte USB Schnittstelle auf einen emulierten COM Port umbiegen.
Befehle könnten sein:
[code]net use com1 \\MEINNOTEBOOK\usb[/code]

allerdings will das nicht so ganz funktionieren bei mir. ;(