Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

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, 6460 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
VB for Applications
gelöst Zelle in Excel per Klick einfärben (5)

Frage von C.Mue83 zum Thema VB for Applications ...

Neue Wissensbeiträge
Drucker und Scanner

Samsung SL-M4025ND, firmware update und (kompatible) Tonerkassetten

(1)

Erfahrungsbericht von markus-1969 zum Thema Drucker und Scanner ...

Router & Routing

PfSense auf Supermicro Intel Xeon D-15x8 SoC Bare Bone

Tipp von Dobby zum Thema Router & Routing ...

Windows Server

Exchange 2010 auf Windows Server 2016 und AD

(2)

Tipp von Herbrich19 zum Thema Windows Server ...

Heiß diskutierte Inhalte
Basic
Programmierung von Windows Programmen (9)

Frage von Ghost108 zum Thema Basic ...

LAN, WAN, Wireless
Brauche Hilfe: Mit (schnellem) WLAN Strecke überbrücken (9)

Frage von pierrehansen zum Thema LAN, WAN, Wireless ...

C und C++
Fehlendes verständiss von C und C++ (8)

Frage von zelamedia zum Thema C und C ...