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

gelöst Leere Zeile

Mitglied: charmeur

charmeur (Level 1) - Jetzt verbinden

07.08.2011, aktualisiert 02:43 Uhr, 3375 Aufrufe, 11 Kommentare, 1 Danke

Hallo ihr
ich habe noch mal eine frage, und zwar im folgenden code wird eine txt datei ausgelesen und in einer msgbox widergegeben
doch leider erscheint die msgbox auch wenn nichts in der zeile steht wie kann ich das unterbinden?
und noch eine glizekleine frage
wie bekomme ich es hin, das ich eine msgbox mit zwei button (ja/nein) habe, die jenachdem was gdrückt wird verschiedene ausführungen tätigen


01.
Option Explicit 
02.
on error resume next 
03.
Dim oXL 
04.
Dim arrLines 
05.
Dim WshShell 
06.
Dim iReturn 
07.
Dim sMessage, sTitel, sTitel1 
08.
 
09.
arrLines = DownloadArray("http://tspo...../media/hs/hh/1.txt") 
10.
 
11.
If VarType(arrLines) <> vbEmpty Then 
12.
 
13.
 'Fenstertitel erstes fenster 
14.
  sTitel = arrLines(2) 
15.
  sTitel1 = arrLines(4) 
16.
 
17.
If not arrLines(3) = "" Then 
18.
    sMessage = "Hallo " & arrLines(0) & "INFOS!!!" & vbNewLine & vbNewLine & "bezahlt bis --> " & arrLines(1) & "         Stand --> " & arrLines(7) & vbNewLine & "  dabei seit --> " & arrLines(9) & vbNewLine & arrLines(10) 
19.
    Set WshShell = CreateObject("WScript.Shell") 
20.
    iReturn = WshShell.Popup(sMessage, arrLines(8), sTitel, vbInformation) 
21.
  End If 
22.
 
23.
  Select Case iReturn 
24.
    Case -1 
25.
      sMessage = arrLines(0) 
26.
  End select 
27.
   
28.
 
29.
  If not arrLines(5) = "" Then 
30.
  iReturn = WshShell.Popup(arrLines(5), 0, sTitel1, vbInformation) 
31.
  End If 
32.
 
33.
 
34.
   
35.
If not arrLines(6) = "6 -" Then 
36.
  WshShell.Run arrLines(6) 
37.
  End If 
38.
 
39.
End If 
40.
Public Function DownloadArray(ByVal URL) 'As String 
41.
  Dim WebReq 'As MsXml2.XmlHttp 
42.
  Dim FSO 'As Scripting.FileSystemObject 
43.
  Set WebReq = CreateObject("WinHttp.WinHttpRequest.5.1") 
44.
  Set FSO = CreateObject("Scripting.FileSystemObject") 
45.
  WebReq.Open "get", URL, False 
46.
  WebReq.Send 
47.
  DownloadArray = Split(WebReq.ResponseText, vbLf) 
48.
End Function 
49.
 
50.
 
51.
 
52.
 
Mitglied: Centauri
07.08.2011 um 09:56 Uhr
Hallo Charmeur,

Ich vermute, dass deine Zeilen nicht ganz leer sind. versuche mal mit Trim eventuelle Leerzeichen zu entfernen.

Für Meldefenster nehme ich immer Msgbox("Test","Titel",vbyesno)

Du kannst das Ergebnis gegen vbyes oder vbno prüfen.

Tschüss

Centauri
Bitte warten ..
Mitglied: 76109
07.08.2011 um 10:09 Uhr
Hallo charmeur!

Ist das ein VBS- oder VBA-Code?

Beispiel für Ja/Nein/Nothing:
01.
Set WshShell = CreateObject("WScript.Shell") 
02.
     
03.
Select Case WshShell.PopUp("Message", 3, "Titel", vbInformation Or vbYesNo) 
04.
    Case vbNo 
05.
        'Nein 
06.
    Case vbYes 
07.
        'Ja 
08.
    Case Else 
09.
        'Zeit abgelaufen 
10.
End Select
Und anstelle von
If VarType(arrLines) <> vbEmpty Then
kannst Du auch
If IsArray(arrLines) Then
schreiben

Gruß Dieter
Bitte warten ..
Mitglied: charmeur
07.08.2011 um 15:35 Uhr
Zitat von 76109:
Hallo charmeur!

Ist das ein VBS- oder VBA-Code?

Beispiel für Ja/Nein/Nothing:
01.
> Set WshShell = CreateObject("WScript.Shell") 
02.
>      
03.
> Select Case WshShell.PopUp("Message", 3, "Titel", vbInformation Or vbYesNo) 
04.
>     Case vbNo 
05.
>         'Nein 
06.
>     Case vbYes 
07.
>         'Ja 
08.
>     Case Else 
09.
>         'Zeit abgelaufen 
10.
> End Select 
11.
> 
Und anstelle von
If VarType(arrLines) <> vbEmpty Then
kannst Du auch
If IsArray(arrLines) Then
schreiben

Gruß Dieter


Hallo Dieter
das sollte ein VBS code sein, aber so 100%ig ist der sicher nicht, da ich mich eigentlich nicht wirklich mit vbs auskenne
sind sicher auch vba komponenten drinne
Bitte warten ..
Mitglied: charmeur
07.08.2011 um 16:46 Uhr
Zitat von Centauri:
Hallo Charmeur,

Ich vermute, dass deine Zeilen nicht ganz leer sind. versuche mal mit Trim eventuelle Leerzeichen zu entfernen.

Für Meldefenster nehme ich immer Msgbox("Test","Titel",vbyesno)

Du kannst das Ergebnis gegen vbyes oder vbno prüfen.

Tschüss

Centauri


Hallo Centauri
also die linie in der TXT sind leer trotzdem kommt dann das msgbox und ist eben leer
Bitte warten ..
Mitglied: rubberman
07.08.2011 um 17:38 Uhr
Hallo charmeur.

In der Funktion "DownloadArray" wird ein Array erzeugt, in dem der Inhalt der Datei an Zeilenumbrüchen aufgesplittet wird.
Sollte in deiner Textdatei ein Zeilenumbruch vorhanden sein, dann ist die Datei schon nicht mehr leer und das Array wird angelegt. Das Array hat dann ein Element mit einer leeren Zeichenfolge. Die Abfrage
If VarType(arrLines) <> vbEmpty Then
kanns du dann genauso vergessen, wie die von Dieter vorgeschlagene Version
If IsArray(arrLines) Then
Diese Zeile prüft letztlich nur, ob die Funktion was geliefert hat.

Du kannst also nur zusätzlich prüfen, ob das erste Element eine leere Zeichenfolge enthält, á la
If arrLines(0) = "" Then
und mit dieser Bedingung den weiteren Ablauf abbrechen.

Grüße
rubberman
Bitte warten ..
Mitglied: charmeur
07.08.2011 um 18:28 Uhr
Zitat von rubberman:
Hallo charmeur.

In der Funktion "DownloadArray" wird ein Array erzeugt, in dem der Inhalt der Datei an Zeilenumbrüchen
aufgesplittet wird.
Sollte in deiner Textdatei ein Zeilenumbruch vorhanden sein, dann ist die Datei schon nicht mehr leer und das Array wird angelegt.
Das Array hat dann ein Element mit einer leeren Zeichenfolge. Die Abfrage
If VarType(arrLines) <> vbEmpty Then
kanns du dann genauso vergessen, wie die von Dieter vorgeschlagene Version
If IsArray(arrLines) Then
Diese Zeile prüft letztlich nur, ob die Funktion was geliefert hat.

Du kannst also nur zusätzlich prüfen, ob das erste Element eine leere Zeichenfolge enthält, á la
If arrLines(0) = "" Then
und mit dieser Bedingung den weiteren Ablauf abbrechen.

Grüße
rubberman

Hallo rubberman
also irgend wie funktioniert das nicht bei mir
in meiner txt datei ist in der zeile 5 nichts drinne dann müsste doch mit der option
01.
If arrLines(0) = "" Then 
02.
end if
der befehl übersprungen werden oder?

also der hindergrund ist dieser das wenn in der txt datei die zeile 5 leer ist soll die msgbox gar nicht erst aufgemacht werden dies wollte ich eben mit der oberen option machen

01.
If arrLines(5) = "" Then 
02.
 
03.
'zweitest Fenster 
04.
iReturn = WshShell.Popup(arrLines(5), arrLines(8), arrLines(4), vbInformation) 
05.
End If
Bitte warten ..
Mitglied: bastla
07.08.2011 um 18:38 Uhr
Hallo charmeur!

Die Zeile 5 steht in "arrLines(4)" ...

Grüße
bastla
Bitte warten ..
Mitglied: rubberman
07.08.2011 um 18:51 Uhr
Hallo bastla,

so ist es.
Ein Unsicherheitsfaktor bleibt aber noch (hatte ich ganz vergessen zu erwähnen). Ich habe mit ein paar Dateien getestet, die mir Google ausgespuckt hat, weil mir hier kein anderes Netzwerk zur Verfügung steht. Bei allen Tests kamen die Zeilenumbrüche nur als Line Feed. Aus dem Grund habe ich vbLf als Separator verwendet. Nun könnte aber unter Umständen ein Carriage Return im Array stehen.

@charmeur

Teste mal, ob sich mit ...
  DownloadArray = Split(WebReq.ResponseText, vbCrLf)
... in der Funktion noch irgendwas tut.

Grüße
rubberman
Bitte warten ..
Mitglied: charmeur
07.08.2011 um 18:52 Uhr
Zitat von bastla:
Hallo charmeur!

Die Zeile 5 steht in "arrLines(4)" ...

Grüße
bastla

ok überredet aber das ergebnis ist das gleiche
Bitte warten ..
Mitglied: bastla
07.08.2011 um 19:46 Uhr
Hallo charmeur!

Dann lade die Datei mit dem folgenden Script einmal herunter und speichere sie damit lokal:
01.
URL = "http://tspo...../media/hs/hh/1.txt" 
02.
Set WebReq = CreateObject("WinHttp.WinHttpRequest.5.1") 
03.
Set FSO = CreateObject("Scripting.FileSystemObject") 
04.
WebReq.Open "get", URL, False 
05.
WebReq.Send 
06.
fso.CreateTextFile("D:\1.txt").Write WebReq.ResponseText
- dann kannst Du sie mit einem Hex-Editor genauer untersuchen (auch hinsichtlich der Zeilenschaltungen) ...

Grüße
bastla
Bitte warten ..
Mitglied: charmeur
08.08.2011 um 01:03 Uhr
ok hat funktioniert danke an alle
Bitte warten ..
Ähnliche Inhalte
VB for Applications

Excel 2013 - farbig formatierte Zeilen werden nicht als leere Zeilen deklariert

Frage von BigMike55VB for Applications3 Kommentare

Hallo, ich habe mir das folgende Makro geschrieben, das funktiert auch wunderbar - bis auf einen "Schönheitsfehler". Per Clickbutton ...

Microsoft Office

Excel: viele leere Zeilen zwischendurch - effizient löschen?

gelöst Frage von PixL86Microsoft Office9 Kommentare

Guten Morgen werte Admincommunity, ACHTUNG. ggf. Freitagsfrage: habe eine Excelliste bekommen mit ca. 10k Datensätzen: aufgebaut nach folgendem Schema: ...

Batch & Shell

Poweshell Script soll String ersetzen und die leere Zeile löschen

gelöst Frage von Mars123Batch & Shell4 Kommentare

Guten Tag, ich habe heute an einem Script gearbeitet, dass rekursiv mehrere Dateien nach einem String durchsucht und diesen ...

Microsoft Office

Word2010: Serienbrief Zeile bei leeren Feld überspringen innerhalb einer Tabelle

Frage von dafdagMicrosoft Office1 Kommentar

Hallo zusammen, ich habe ein Word2010 Serienbrief das mit einer Excel Datenquelle verknüpft ist. Sobald ein leeren Datensatz vorkommt ...

Neue Wissensbeiträge
iOS
IOS 11.2.6 verfügbar
Information von sabines vor 4 StundeniOS

Mit dem Update soll der Bug behoben werden, bei dem eine bestimmte Zeichenkette IOS zum Absturz gebracht hat.

Sicherheit
Sicherheitsrisiko: Die Krux mit 7-Zip
Information von kgborn vor 18 StundenSicherheit2 Kommentare

Bei vielen Anwendern ist das Tool 7-Zip zum Entpacken von Archivdateien im Einsatz. Die Software ist kostenlos und steht ...

Internet

Datendealing im WWW Tracking Methoden immer brutaler

Information von sabines vor 1 TagInternet

Interessanter Artikel zum Thema Tracking im WWW und die immer "besseren" Methoden des Trackings. Professor Arvind Narayanan (Princeton-Universität) betreibt ...

Erkennung und -Abwehr

Ups: Einfaches Nullzeichen hebelte den Anti-Malware-Schutzt in Windows 10 aus

Information von kgborn vor 1 TagErkennung und -Abwehr

Windows 10 ist das sicherste Windows aller Zeiten, wie Microsoft betont. Insidern ist aber klar, das es da Lücken, ...

Heiß diskutierte Inhalte
Server
Route-Befehl Unterstützung (unter CMD)
gelöst Frage von FKRR56Server38 Kommentare

Guten Tag , i.M. habe ich Probleme über den CMD-Route-Befehl ein Routing auf einen entfernten Server zuzulassen. Der Server ...

LAN, WAN, Wireless
VPN Cisco ASA5505 PaloAlto PA-200
gelöst Frage von YannoschLAN, WAN, Wireless19 Kommentare

Hallo zusammen, ich würde gerne ein Site-to-Site VPN zwischen den beiden Standorten aufbauen. PaloAlto PA200 Internetanschluss Deutsche Telekom GK ...

Microsoft
TV-Tipp: Das Microsoft-Dilemma
Information von kgbornMicrosoft17 Kommentare

Aktuell gibt es in Behörden und in Firmen eine fatale Abhängigkeit von Microsoft und dessen Produkten. Planlos agieren die ...

Server-Hardware
Server für Exchange 2016, Kaufberatung
Frage von MazenauerServer-Hardware15 Kommentare

Guten Tag werte Gemeinde, Vorab: Ich dachte es gab mal einen separaten Bereich für solche Anfragen, habe ich leider ...