Validate 4d string data with regex by data type
Validate 4d string data with regex by data type
Match regex
is a great addition to 4Dv11, but what I really need is a function that takes a string value, a data type and tells me if it’s valid or not.
I’m no regex expert, just compiled some online examples into one function. This is only a starting point, but it completes my needs for the time being. There is a whole forum section devoted to this online.
` ----------------------------------------------------
` User name (OS):
` Date and time: 11/02/10, 15:29:39
` ----------------------------------------------------
` Method: UTIL_ValidateDataByType
` Description
` We want to have a method that will validate data by it's type
`
` Parameters
` ----------------------------------------------------
`$0 returns true or false based on validity
`$1 text data to validate cast as String
`$2 longint type of data expected
`$3 boolean show alerts (optional) assumed false
C_BOOLEAN($0;$vb_Return;$3;$vb_ShowAlerts)
C_TEXT($1;$vt_Data;$vt_Pattern)
C_LONGINT($2;$vl_DataType;$vl_ParameterCount)
` count the parameters
$vl_ParameterCount:=Count parameters
` assume we'll fail
$vb_Return:=False
` assume we don't want to see alerts
$vb_ShowAlerts:=False
If ($vl_ParameterCount>=2)
` lets check them
$vt_Data:=$1
$vl_DataType:=$2
If ($vl_ParameterCount>=3)
$vb_ShowAlerts:=$3
End if
Case of
: ($vl_DataType=Is Alpha Field ) | ($vl_DataType=Is Text )
` we passed in a string didn't we?
$vb_Return:=True
: ($vl_DataType=Is Boolean )
$vt_Data:=Lowercase($vt_Data)
Case of
: (($vt_Data="true") | ($vt_Data="false"))
` expecting "true" or "false"
$vb_Return:=True
: ($vb_ShowAlerts)
ALERT("Expecting 'True' or 'False' not "+$vt_Data)
End case
: ($vl_DataType=Is Integer ) | ($vl_DataType=Is LongInt )
` integer only, no size restriction
$vt_Pattern:="[-+]?\\b\\d+\\b"
Case of
: (Match regex($vt_Pattern;$vt_Data))
$vb_Return:=True
: ($vb_ShowAlerts)
ALERT("Expecting signed integer not "+$vt_Data)
End case
: (($vl_DataType=Is Real ) | ($vl_DataType=Is Float ))
`decimal
$vt_Pattern:="[-+]?((\\b[0-9]+)?\\.)?[0-9]+\\b"
Case of
: (Match regex($vt_Pattern;$vt_Data))
$vb_Return:=True
: ($vb_ShowAlerts)
ALERT("Expecting decimal value not "+$vt_Data)
End case
: ($vl_DataType=Is Date )
` Date d/m/yy and dd/mm/yyyy 1/1/00 through 31/12/99 and 01/01/1900 through 31/12/2099
` ie europeon or american style dates accepted, deliminated with '-' ' ' '/' OR '.'
$vt_Pattern:="\\b(0?[1-9]|[12][0-9]|3[01])[- /.](0?[1-9]|1[012])[- /.](19|20)?[0-9]{2}\\b"
Case of
: (Match regex($vt_Pattern;$vt_Data;1))
$vb_Return:=True
: ($vb_ShowAlerts)
ALERT("Expecting d/m/yy or dd/mm/yyyy not "+$vt_Data)
End case
: ($vl_DataType=Is Time )
` Time in 24 hours format with optional seconds
$vt_Pattern:="^(([0-1]?[0-9])|([2][0-3])):([0-5]?[0-9])(:([0-5]?[0-9]))?$"
Case of
: (Match regex($vt_Pattern;$vt_Data))
$vb_Return:=True
: ($vb_ShowAlerts)
ALERT("Expecting HH:MM or HH:MM:SS in 24hr format not "+$vt_Data)
End case
Else
` not checking blobs, pictures, subtables. just move on
$vb_Return:=True
End case
Else
$vb_Return:=False
End if
$0:=$vb_Return
Significant Revisions
- May 6th, 2024 Converted to jekyll markdown format and copied to personal site
- Nov 3rd, 2010 Originally published on txcowboycoder wordpress site1
Footnotes
-
Initial
md
Generated using https://github.com/jsr6720/wordpress-html-scraper-to-mdOriginal Wordpress categories: [‘4D’]
Original Wordpress tags: “4D”, “4D”, “Match regex”, “regex” ↩