473,383 Members | 1,885 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes and contribute your articles to a community of 473,383 developers and data experts.

Use IsCharAlphaNumeric() Rather Than ASCII Values

ADezii
8,834 Expert 8TB
Many times we need to determine if a particular character, whether alone, or among other characters in a String, is an AlphaNumeric character (if it falls in the range of characters from A - Z, or a to z, or 0 - 9). The traditional method of doing this in VBA is to compare the Asc(UCase(character)) to the ANSI values for the ranges. The Windows API, however, provides a Function designed specifically for this purpose IsCharAlphaNumeric(). IsCharAlphaNumeric() is significantly faster than its counterpart. You simply pass the ASCII value of the character as an Argument to this Function and it returns True if the character is AlphaNumeric and False if it is not. Both the slow and faster versions of the code will be illustrated below. Be sure to Declare the API Function(s) in the Declarations Section of a Module.
  1. Slow version of the code:

    Expand|Select|Wrap|Line Numbers
    1.  strTestChar As String, intTestChar As Integer
    2. Const conFirstChar = 65
    3. Const conLastChar = 90
    4. Const conFirstDigit = 48
    5. Const conLastDigit = 57
    6.  
    7. strTestChar = "4"
    8. intTestChar = Asc(UCase(strTestChar))
    9.  
    10. If (intTestChar >= conFirstChar And intTestChar <= conLastChar) Or _
    11. (intTestChar >= conFirstDigit And intTestChar <= conLastDigit) Then
    12. 'the character is AlphaNumeric
    13. Else
    14. 'the character is Not AlphaNumeric
    15. End If
  2. Faster and more efficient version of the code:

    Expand|Select|Wrap|Line Numbers
    1.  Private Declare Function IsCharAlphaNumeric Lib "User32" Alias "IsCharAlphaNumericA" (ByVal cChar As Byte) As Long
    2. Private Declare Function IsCharAlpha Lib "User32" Alias "IsCharAlphaA" (ByVal cChar As Byte) As Long
    Expand|Select|Wrap|Line Numbers
    1. IsCharAlphaNumeric(Asc(strTestChar)) Then
    2. 'the character is AlphaNumeric
    3. Else
    4. 'the character is Not AlphaNumeric
    5. End If
    6.  
    7. 'Similiar Function to test for Alphas
    8. If IsCharAlpha(Asc(strTestChar)) Then
    9. 'the character is an Alpha
    10. Else
    11. 'the character is Not an Alpha
    12. End If
  3. NOTE: There is also a similar API Function (IsCharAlpha()) that checks a character to see whether itis an Alpha (a - z or A - Z). Its code and Declaration is also listed.
Jun 17 '07 #1
2 9628
I'm trying this out. The business need is having to filter out records containing fields where non alphanumeric (@, ., !) characters are contained within one of its fields. The remaining records are those which have to be researched. Eliminating the non-pertinent records using automation will save approx. 20 minutes each time this audit is performed. Thanks!

I'll try to report back to the thread on whether or not this application of the method was successfull.
Dec 11 '07 #2
ADezii
8,834 Expert 8TB
I'm trying this out. The business need is having to filter out records containing fields where non alphanumeric (@, ., !) characters are contained within one of its fields. The remaining records are those which have to be researched. Eliminating the non-pertinent records using automation will save approx. 20 minutes each time this audit is performed. Thanks!

I'll try to report back to the thread on whether or not this application of the method was successfull.
Hope this works out for you, it is the most efficient Method for establishing whether or not a character is AlphaNumeric.
Dec 11 '07 #3

Sign in to post your reply or Sign up for a free account.

Similar topics

6
by: Drew | last post by:
I need to display the ASCII numeric values of each letter in a string. I think strings are stored in unicode in C# (?) I can convert the string to a char array but how do I get the ascii values...
1
by: Kermit Piper | last post by:
Hello, I have a function that lets me convert one character and throw an alert with the corresponding ASCII value, but what I am having trouble with is applying it to a text box. What I'm trying...
1
by: Kermit Piper | last post by:
Hello, OK, almost there. Here's what I have so far, which handles characters as they're typed in. Could someone please show me how I would loop through all the values that are entered if a block...
7
by: Jeffrey Spoon | last post by:
Hello, I'm a bit stuck trying to convert a text file which contains extended ASCII text and changing the ASCII values so they become readable. I do this by subtracting 127 from the ASCII value....
1
by: adnanahmed714 | last post by:
hi all i have a string <cr><lf>999,1.52,32.85,5.91,15.81,1.39,26.17,15.75,12.3 want to calculate its ASCII values sum which is equal to 2411.How can i calculate ascii sum of all the...
1
by: Bangaru | last post by:
Hi, How do SQL 2005 handle Non-ASCII values? My application is in VB 6 and SQL server 2005, and when I import non-ascii values like pound symbol, it is converted to question mark... Can...
0
by: nmsreddi | last post by:
Hi friends I am working on serialport in c# ,i am using C#2005 i have successfully done the serial communication with GSM modem and able to send and receive data , the main problem ,the serial...
10
by: manontheedge | last post by:
I want to read in an image file ( bmp, jpeg, ... ) so I can retain it's ascii / binary values, and alter the image. How can I do this in C++ ( I'm using Visual Studio, various versions ). so...
0
by: squrel | last post by:
Hello All, I have a table in my database with a field itemqty and the type was int and need to change it to decimal as i need the decimal point in my textbox.. i have a code for integer ascii...
5
by: siddhanta | last post by:
hi, i read the ascii value from a file and wrote the decimal one in other file. But values above "127" i.e. extended ascii are printed as" 65533." here ais wat i did: private void...
1
by: CloudSolutions | last post by:
Introduction: For many beginners and individual users, requiring a credit card and email registration may pose a barrier when starting to use cloud servers. However, some cloud server providers now...
0
isladogs
by: isladogs | last post by:
The next Access Europe User Group meeting will be on Wednesday 3 Apr 2024 starting at 18:00 UK time (6PM UTC+1) and finishing by 19:30 (7.30PM). In this session, we are pleased to welcome former...
0
by: ryjfgjl | last post by:
In our work, we often need to import Excel data into databases (such as MySQL, SQL Server, Oracle) for data analysis and processing. Usually, we use database tools like Navicat or the Excel import...
0
by: Charles Arthur | last post by:
How do i turn on java script on a villaon, callus and itel keypad mobile phone
0
by: ryjfgjl | last post by:
If we have dozens or hundreds of excel to import into the database, if we use the excel import function provided by database editors such as navicat, it will be extremely tedious and time-consuming...
0
by: ryjfgjl | last post by:
In our work, we often receive Excel tables with data in the same format. If we want to analyze these data, it can be difficult to analyze them because the data is spread across multiple Excel files...
0
by: emmanuelkatto | last post by:
Hi All, I am Emmanuel katto from Uganda. I want to ask what challenges you've faced while migrating a website to cloud. Please let me know. Thanks! Emmanuel
0
BarryA
by: BarryA | last post by:
What are the essential steps and strategies outlined in the Data Structures and Algorithms (DSA) roadmap for aspiring data scientists? How can individuals effectively utilize this roadmap to progress...
1
by: nemocccc | last post by:
hello, everyone, I want to develop a software for my android phone for daily needs, any suggestions?

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.