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

Excel Datenüberprüfung auf Zelle mit Format hhmm

Frage Microsoft Microsoft Office

Mitglied: Michi1

Michi1 (Level 1) - Jetzt verbinden

12.03.2013 um 16:53 Uhr, 6871 Aufrufe, 2 Kommentare, 1 Danke

Mittels einer Datenüberprüfung soll verhindert werden, dass Benutzer falsche Werte in Zellen mit benutzerdefiniertem Format eingeben.

Hallo Forum,

ich möchte in Excel 2007/2010 (sxls-Format) in Zellen, die das benutzerdefinierte Format [hh]:mm (mit den eckigen Klammern!) haben verhindern, dass Benutzer andere Werte (z.B. 12.45) eingeben können. Die Eingabe muss zwingend mit ":" erfolgen.
Es soll auch möglich sein negative Werte einzugeben. Also z.B. 12:45 oder -12:45.

Ich habs leider nicht hinbekommen ein gültige Formel für die Datenüberpüfung zu hinterlegen und im Internet auch noch keine Lösung dafür gefunden.

Kann mir da jemand von euch helfen?

Vielen Dank!

Michi
Mitglied: Friemler
12.03.2013 um 22:04 Uhr
Hallo Michi,

die Datenüberprüfung ist nicht besonders sicher. Wenn z.B. ein unzulässiger Wert durch Copy&Paste in die Zelle eingefügt wird, greift die Datenüberprüfung nicht, in dem Fall wird sie sogar beseitigt.

Besser wäre es, folgendes VBA-Makro in das entsprechende Arbeitsblatt oder die Arbeitsmappe einzufügen:
01.
Private Sub Worksheet_Change(ByVal Target As Excel.Range) 
02.
  Dim objRegExp As Object 
03.
  Dim mbrChoice As VbMsgBoxResult 
04.
 
05.
  If Target.Cells.Count < 1 Then Exit Sub 
06.
  If IsEmpty(Target) Then Exit Sub 
07.
  If Target.NumberFormat <> "[hh]:mm" Then Exit Sub 
08.
 
09.
  Application.EnableEvents = False 
10.
     
11.
  Set objRegExp = CreateObject("VBScript.RegExp") 
12.
  objRegExp.Pattern = "^[-]*([01][0-9]|2[0-3]):[0-5][0-9]$" 
13.
    
14.
  If Not objRegExp.Test(Trim(Target.Cells(1, 1).Text)) Then 
15.
    Target.Cells(1, 1).Activate 
16.
       
17.
    mbrChoice = MsgBox("Geben Sie die Zeit im Format [-]HH:MM ein.", _ 
18.
                       vbApplicationModal + vbCritical + vbRetryCancel + vbDefaultButton1, _ 
19.
                       "Falsches Format") 
20.
       
21.
    Target.Cells.ClearContents 
22.
    If mbrChoice = vbRetry Then SendKeys "{F2}" 
23.
  End If 
24.
     
25.
  Application.EnableEvents = True 
26.
End Sub
Hier wird für die Prüfung die Klasse für Reguläre Ausdrücke aus VBScript verwendet. Dadurch ist auch die Erkennung von ungültigen Uhrzeiten (z.B. 24:05 oder 23:130) möglich.

Bei dem verwendeten Zahlenformat "[hh]:mm" wirst Du allerdings Probleme mit der Eingabe von negativen Werten bekommen. Definiere besser "* @" als Zahlenformat (ohne Anführungszeichen), Du musst das dann auch in Zeile 7 des obigen Scripts anpassen. Die Uhrzeiten werden dadurch als Text rechtsbündig angezeigt.

Gruß
Friemler
Bitte warten ..
Mitglied: Michi1
14.03.2013 um 16:18 Uhr
Hallo Friemler,

tausend Dank!
Hat alles super funktioniert.
Für die Prüfung in der Mappe hab ich den Namen der Sub entsprechend angepasst:

Private Sub Workbook_SheetChange(ByVal Sh As Object, ByVal Target As Excel.Range)

Viele Grüße
Michi
Bitte warten ..
Ähnliche Inhalte
Microsoft Office
Excel Number Format wechselt random zu Currency Format
Frage von YauhunMicrosoft Office2 Kommentare

Hallo zusammen, es geht um Office 2016 Standard auf einem Windows 7 Betriebssystem. Das Problem tritt spontan auf, vielleicht ...

Microsoft Office
Excel Liste mit Datenüberprüfung anlegen und anschließend selektieren ????
gelöst Frage von speedy132Microsoft Office10 Kommentare

Hallo, ich habe in Excel eine Mitarbeiterliste erstellt. Diese einen Namen vergeben und über Datenüberprüfung - Liste diese angesprochen. ...

Microsoft Office
Excel Tabellenblattname in Zelle schreiben
gelöst Frage von abuelitoMicrosoft Office8 Kommentare

Hallo an Alle, ich habe folgendes Problem: Ich habe eine Exceltabelle immer mit unterschiedlichen Zeilen und möchte gerne den ...

Microsoft Office
Excel Zellen übernehmen
gelöst Frage von Florian86Microsoft Office3 Kommentare

Hallo, ich möchte Daten von einem Tabellenblatt per Makro auf ein anderes übernehmen. Jetzt habe ich folgendes gemacht Sub ...

Neue Wissensbeiträge
Tipps & Tricks

Solutio Charly Updater Fehlermeldung: Das Abgleichen der Dateien in -Pfad- mit dem Datenobject ist fehlgeschlagen

Tipp von StefanKittel vor 4 StundenTipps & Tricks

Hallo, hier einmal als Tipp für alle unter Euch die mit der Zahnarztabrechnungssoftware Charly von Solutio zu tun haben. ...

Sicherheit

Meltdown und Spectre: Wir brauchen eine "Abwrackprämie", die die CPU-Hersteller bezahlen

Information von Frank vor 4 StundenSicherheit6 Kommentare

Zum aktuellen Thema Meltdown und Spectre: Ich wünsche mir von den CPU-Herstellern wie Intel, AMD oder ARM eine Art ...

Sicherheit

Meltdown und Spectre: Realitätscheck

Information von Frank vor 5 StundenSicherheit4 Kommentare

Die unangenehme Realität Der Prozessorfehler mit seinen Varianten Meltdown und Spectre ist seit Juni 2017 bekannt. Trotzdem sind immer ...

Sicherheit

Meltdown und Spectre: Die machen uns alle was vor

Information von Frank vor 5 StundenSicherheit12 Kommentare

Aktuell sieht es in den Medien so aus, als hätten die Hersteller wie Intel, Microsoft und Co den aktuellen ...

Heiß diskutierte Inhalte
Windows 10
Netbook erkennt Soundkarte nicht - keinerlei Info zum Hersteller und Modell vom Netbook und Hardware bekannt
Frage von 92943Windows 1031 Kommentare

Guten Tag, meine Schwester reist in einigen Wochen für ein paar Monate ins Ausland und hat sich dafür ein ...

Batch & Shell
Anmeldevorgang für Informatikraum (Schule) unter Windows
gelöst Frage von IngenieursBatch & Shell29 Kommentare

Hey zusammen, ich werde in naher Zukunft den Informatik Raum meiner jetzigen Schule von dem aktuellen Betreiber übernehmen (Vertrag ...

Netzwerkgrundlagen
Welches Modem für VDSL 50000 der T-Com
Frage von Windows10GegnerNetzwerkgrundlagen19 Kommentare

Hallo, ein Kollege von mir will sich VDSL50000 von der T-Com holen, um daran einen Server zu betreiben. Ich ...

Batch & Shell
AD-Abfrage in Batchdatei und Ergebnis als Variable verarbeiten
gelöst Frage von Winfried-HHBatch & Shell19 Kommentare

Hallo in die Runde! Ich habe eine Ergänzungsfrage zu einem alten Thread von mir. Ausgangslage ist die Batchdatei, die ...