Top-Themen

Aktuelle Themen (A bis Z)

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit

Frage Entwicklung VB for Applications

GELÖST

Teilstring aus Dateinamen auslesen?

Mitglied: dodyou

dodyou (Level 1) - Jetzt verbinden

28.11.2013 um 21:53 Uhr, 3940 Aufrufe, 3 Kommentare, 2 Danke

Hallo beisammen,
ich versuche zwei Makros zu programmieren, die folgende Informationen aus dem jeweils aktuellen Dateinamen herauslesen und in ein Word-Dokument einfügen:

nämlich „Aktenzeichen“ und „Dokumentennummer“.

Die Dateinamen sind dabei wie folgt aufgebaut:
10-24743-06_XYZMuc_58495.DOCX
Die Dokumentennummer ist: 58495
Das Aktenzeichen ist: 24743

Alternativ könnte es auch so sein:
Der Dateinamen ist wie folgt aufgebaut:
10-A III 24743-06_XYZMuc_58495.DOCX
Die Dokumentennummer ist: 58495
Das Aktenzeichen ist: A III 24743

In beiden Fällen steht die Dokumentennummer immer hinter dem zweiten Unterstrich und vor dem Punkt (wenn die Dateiendung überhaupt "vorhanden" ist)
In beiden Fällen steht also steht das Aktenzeichen immer zwischen den zwei Bindestrichen.

Folgenden Eigenheiten sind zu beachten:
in Abhängigkeit davon, welche Einstellungen der jeweilige Benutzer vorgenommen hat (bekannte Dateiendungen anzeigen. j/n) wird das DCOX als Dateiendung in der Variable Dateiname (Schnellbausteine – Feld) mit übergeben oder auch nicht. Es gibt auch einzelne Dokumente, die noch im Doc-Format vorliegen.

Die Länge (Anzahl der Zeichen) von Aktenzeichen und Dokumentennummer sind von Dokument zu Dokument unterschiedlich, wird aber mindestens 5 Zeichen umfassen, mit zunehmender Tendenz. Die mit einem „–“ von dem Aktenzeichen getrennten Ziffern (hier: 10 und 06) werden wohl zweistellig bleiben (könnten höchstens dreistellig werden; wenn das zu höherer Komplexität führen würde, können wir das auch so festlegen, dass die immer zweistellig bleiben) , wie auch die Bindestriche vor und dahinter wie auch das „_XYZMuc_“ sind irrelevant.

Im Alternativfall könnten anstelle von „A III“ auch stehen: A I, A II, A IV, A V oder WZ. Es ist aber sicher, dass das Aktenzeichen von zwei „–“ „umrahmt“ ist.

Ich denke an folgende Lösung, jedoch fehlen mir als VBA-Laie die richtigen Befehle/Operatoren

dateiname = Dateiname
gesamtlaenge = Laenge(dateiname)
For x = 1 to gesamtlaenge
buchstabe = instr(dateiname, x, 1)
if buchstabe = "-"
if ersterBindestrich = 0
ersterBindestrich = x
else zweiterBindstrich = x
endif
endif
if buchstabe = "_"
if ersterUnterstrich = 0
ersterUnterstrich = x
else zweiterUnterstrich = x
endif
endif
next x
endfor
aktenzeichen = instr(dateiname, ersterBindestrich, zweiterBindestrich)
dokumentenummer = instr(dateiname, ersterUnterstrich, zweiterUnterstrich)

Nun meine ich schon zu wissen, das anstelle von instr zu verwenden ist:

Selection.TypeText (Mid(ActiveDocument.Name, ersterBindestrich, zweiterBindestrich))

Wie aber "gewinne" und belege ich die Variablen ersterBindestrich, zweiterBindestrich?
Für Hilfe jeder Art wäre ich sehr dankbar!
Mitglied: colinardo
28.11.2013, aktualisiert um 22:52 Uhr
Hallo dodyou,
mach das ganze am besten mit Regular Expressions das ist zuverlässiger
01.
Set regex = CreateObject("vbscript.regexp") 
02.
regex.IgnoreCase = True 
03.
regex.Pattern = "-([^\-]+)-.*_(\d{5,})" 
04.
Set matches = regex.Execute(dateiname) 
05.
if matches.count > 0 then 
06.
    aktenzeichen = matches(0).Submatches(0) 
07.
    dokumentennummer = matches(0).Submatches(1) 
08.
End if
Grüße Uwe
Bitte warten ..
Mitglied: bastla
28.11.2013 um 22:44 Uhr
Hallo dodyou!

Ich würde das mit "Split()" versuchen - etwa:
Aktenzeichen = Split(Dateiname, "-")(1) 
Dokumentennummer = Split(Split(Dateiname, "_")(2), ".")(0)
Um den Dateinamen ohne Typ zu erhalten (dann würde
Dokumentennummer = Split(DateinameOhneTyp, "_")(2)
genügen) könntest Du
DateinameOhneTyp = CreateObject("Scripting.FileSystemObject").GetBaseName(Dateiname)
verwenden.

Grüße
bastla
Bitte warten ..
Mitglied: dodyou
29.11.2013 um 16:51 Uhr
Herzlichen Dank für die wirklich schnellen und hilfreichen Reaktionen. Ich habe mich für die (für mich halbwegs verständliche und damit) einfachere Split-Lösung entschieden.
Für Nachahmer die Lösung hier

Sub Aktenzeichen()
Selection.TypeText (Split(ActiveDocument.Name, "-")(1))
End Sub

und

Sub Doknummer()
Selection.TypeText (Split(Split(ActiveDocument.Name, "_")(2), ".")(0))
End Sub

Besten Dank noch einmal, dieses Forum und seine die Poster hier sind wirklich Spitze!
Bitte warten ..
Ähnliche Inhalte
Batch & Shell
Dateinamen auslesen und in einer Schleife benutzen
gelöst Frage von TeholBeddictBatch & Shell12 Kommentare

Hallo Experten, ich kämpfe derzeit mit folgender Aufgabenstellung, welche ich per Batchskript lösen möchte: In einem Ordner sind 1 ...

Batch & Shell
Dateinamen auslesen und in Code einbauen
gelöst Frage von markueBatch & Shell10 Kommentare

Hallo an alle, ich bin neu hier und habe eine für mich knifflige Sache. Ich möchte per .cmd Datei ...

Batch & Shell
Batch: Dateiname abhängig vom Änderungsdatum auslesen
gelöst Frage von freaktastischBatch & Shell6 Kommentare

Servus zusammen, hab folgende Situation Oberordner: beinhaltet test.bat, Ordner1 und Ordner2 Ordner1, sowie Ordner2 beinhalten .docx Dateien. Mein Anliegen ...

Batch & Shell
Dateinamen aus Verzeichnis Auslesen und Stringzerlegung zur Datumsanalyse
gelöst Frage von caspi-pirnaBatch & Shell3 Kommentare

Guten Morgen. Ich habe ein Problem mit einer Batch- Aufgabe. Es soll der Inhalt eines Verzeichnisses überprüft werden. In ...

Neue Wissensbeiträge
Router & Routing

PfSense als Addon auf QNAP

Information von magicteddy vor 7 StundenRouter & Routing2 Kommentare

Moin, für Spielereien eine ganz nette Idee aber ich fürchte das soetwas auch als echte Firewall genutzt wird: In ...

Datenschutz

Teamviewer kommt für IoT-Geräte wie den Raspberry Pi

Information von magicteddy vor 14 StundenDatenschutz

Moin, jetzt werden IoT Geräte endgültig zur Wanze? Anscheinend kann man auf einem Dashboard seine Geräte visualisieren Ich stelle ...

Microsoft

Letzte Updates für Win10 und Server2016 müssen bei Bedarf über den Update catalogue in den WSUS importiert werden!

Tipp von DerWoWusste vor 19 StundenMicrosoft1 Kommentar

automatisch kommt da nichts an im WSUS und auch nicht im SCCM. Siehe Hinweise zum Bezug der jeweils neuesten ...

Linux

Meltdown und Spectre: Linux Update

Information von Frank vor 3 TagenLinux

Meltdown (Variante 3 des Prozessorfehlers) Der Kernel 4.14.13 mit den Page-Table-Isolation-Code (PTI) ist nun für Fedora freigegeben worden. Er ...

Heiß diskutierte Inhalte
Netzwerkmanagement
Preis für Wartungsvertrag ok?
gelöst Frage von a-za-zNetzwerkmanagement22 Kommentare

Hallo! Mal ne Frage, weil ich mich mit dem akzeptablen Preis für einen Reaktionszeitvertrag nicht auskenne. Meine Firma hat ...

Windows Netzwerk
Ist ein Portforwarding auf einen PC ohne lauschendes Programm ein (großes) Sicherheitsproblem?
Frage von PluwimWindows Netzwerk13 Kommentare

Hallo zusammen, zur Fernwartung eines Rechners an einem anderen Ort nutze ich VNC. Da dieser Rechner einfach nur eine ...

Windows Server
Terminal Server 2016 erkennt Berechtigungen nicht
gelöst Frage von Thomas2Windows Server10 Kommentare

Hallo Administratoren, folgendes Problem stellt sich dar: Es gibt zwei Windows Server 2016, die als Terminal Server fungieren. Jetzt ...

Sonstige Systeme
7-zip: Programm frägt nach Passwort erst bei einzelnen Dateien
Frage von freeskierchrisSonstige Systeme7 Kommentare

Guten Morgen, ich habe ein Problem beim Arbeiten mit 7-zip: Wenn ich die einzelnen Dateien zu einem Archiv verpacke ...