delphi 判断字符串是否包含汉字,正则版与非正则版实现

代码一

//正则版

uses RegularExpressions; //相关单元

function IsChineseStr(s: String): Boolean;

const
pattern ='[\x{4E00}-\x{9FA5}]'; //测试用的表达式
begin
Result:=false;
if TRegEx.IsMatch(s, pattern) then
begin
Result:=True;

end;
end;

//非正则版

function isChina(S: string): Boolean;
var
  pStr: PWideChar;
begin
  Result := false;
  pStr := PChar(S);
  while pStr^ <> #0 do
  begin
    case pStr^ of
      Char($4E00)..Char($9FCB):
        begin
          Result := True;
          Break;
        end;
    end;
    Inc(pStr);
  end;
end;

河南-风 delphi学习网 2020/5/26 17:13:33 改进版

function IsChina(S: string): Boolean;
var
  pStr: PWideChar;
  function HexToInt(const HexValue: string): Integer;
  begin
    Val('$' + HexValue, Result, Result);
  end;

  function InChar(AChar: Char; AStart, AEnd: string): Boolean;
  begin
    Result := (Ord(AChar) >= HexToInt(AStart)) and (Ord(AChar) <= HexToInt(AEnd))
  end;
begin
  Result := false;
  pStr := PWideChar(S);
  while pStr^ <> #0 do
  begin
    if InChar(pStr^, '4E00', '9FA5')  //
      or InChar(pStr^, '9FA6', '9FEF')    //基本汉字补充74字
      or InChar(pStr^, '3400', '4DB5')    //扩展A
      or InChar(pStr^, '20000', '2A6D6')  //扩展B42711字
      or InChar(pStr^, '2A700', '2B734')  //扩展C4149字
      or InChar(pStr^, '2B740', '2B81D')  //扩展D222字2B740-2B81D
      or InChar(pStr^, '2B820', '2CEA1')  //PUA(GBK)部件81字E815-E86F
      or InChar(pStr^, 'E815', 'E86F')    //扩展E5762字2B820-2CEA1
      or InChar(pStr^, '2CEB0', '2EBE0')   //扩展F7473字2CEB0-2EBE0
      or InChar(pStr^, '30000', '3134A')   //扩展G4939字30000-3134A
      or InChar(pStr^, '2F00', '2FD5')     //康熙部首214字2F00-2FD5
      or InChar(pStr^, '2E80', '2EF3')     //部首扩展115字2E80-2EF3
      or InChar(pStr^, 'F900', 'FAD9')     //兼容汉字477字F900-FAD9
      or InChar(pStr^, '2F800', '2FA1D')  //兼容扩展542字2F800-2FA1D
      or InChar(pStr^, 'E400', 'E5E8')   //部件扩展452字E400-E5E8
      or InChar(pStr^, 'E600', 'E6CF')   //PUA增补207字E600-E6CF
      or InChar(pStr^, '31C0', '31E3')   //汉字笔画36字31C0-31E3
      or InChar(pStr^, '2FF0', '2FFB')   //汉字结构12字2FF0-2FFB
      or InChar(pStr^, '3105', '312F')   //汉语注音43字3105-312F
      or InChar(pStr^, '31A0', '31BA')   //注音扩展22字31A0-31BA
      or InChar(pStr^, '3007', '3007')   //?1字3007
      then
    begin
      Result := True;
      Break;
    end;
    Inc(pStr);
  end;
end;

版本3:qq281309196 黑夜杀手提供

上面代码可以满足大部分需求。

大悟还俗 DelphiFmx.com 发现非正则得小问题:

想玩精密点得可以参考下面:qq281309196 黑夜杀手提供

到此这篇关于delphi 判断字符串是否包含汉字,正则版与非正则版实现的文章就介绍到这了,更多相关delphi 判断字符串是否包含汉字内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • delphi 判断字符串是否包含汉字,正则版与非正则版实现

    代码一 //正则版 uses RegularExpressions; //相关单元 function IsChineseStr(s: String): Boolean; const pattern ='[\x{4E00}-\x{9FA5}]'; //测试用的表达式 begin Result:=false; if TRegEx.IsMatch(s, pattern) then begin Result:=True; end; end; //非正则版 function isChina(S: stri

  • 使用纯JS代码判断字符串中有多少汉字的实现方法(超简单实用)

    在网站开发中,经常会简单使用js代码来判断字符串中有多少汉字的功能.今天小编抽时间给大家分享实现代码.废话不多说了,直接给大家贴代码了. $("form").submit(function () { var content = editor.getContentTxt(); var sum = 0; re = /[\u4E00-\u9FA5]/g; //测试中文字符的正则 if (content) { if (re.test(content)) //使用正则判断是否存在中文 { if

  • Lua判断字符串中包含中文字符的方法和计算字符串宽度函数分享

    一.判断字符串中包含中文字符的方法 遍历数组,对每个字节使用string.byte(),发现有大于127的,就是汉字,可以参照下面的代码. 二.计算字符串宽度函数 复制代码 代码如下: -- 计算字符串宽度   local str = "Jimmy: 你好,世界!" local fontSize = 20 local lenInByte = #str local width = 0   for i=1,lenInByte do     local curByte = string.by

  • python七种方法判断字符串是否包含子串

    1. 使用 in 和 not in in 和 not in 在 Python 中是很常用的关键字,我们将它们归类为 成员运算符. 使用这两个成员运算符,可以很让我们很直观清晰的判断一个对象是否在另一个对象中,示例如下: >>> "llo" in "hello, python" True >>> >>> "lol" in "hello, python" False 2. 使用

  • oracle 函数判断字符串是否包含图片格式的实例代码

    首先是写一个分割字符串的函数,返回table类型 CREATE OR REPLACE FUNCTION fn_split (p_str IN VARCHAR2, p_delimiter IN VARCHAR2) RETURN ty_str_split IS j INT := 0; i INT := 1; len INT := 0; len1 INT := 0; str VARCHAR2 (4000); str_split ty_str_split := ty_str_split (); BEGI

  • java 判断字符串是否包含子串的方法

    java 判断字符串是否包含子串的方法 方法一: String str1 = "nihaoksdoksad "; String str2 = "ok "; int total = 0; for (String tmp = str1; tmp != null&&tmp.length()> =str2.length();){ if(tmp.indexOf(str2) == 0){ total ++; } tmp = tmp.substring(1)

  • python判断字符串是否包含子字符串的方法

    本文实例讲述了python判断字符串是否包含子字符串的方法.分享给大家供大家参考.具体如下: python的string对象没有contains方法,不用使用string.contains的方法判断是否包含子字符串,但是python有更简单的方法来替换contains函数. 方法1:使用 in 方法实现contains的功能: site = 'http://www.jb51.net/' if "jb51" in site: print('site contains jb51') 输出结

  • PHP简单判断字符串是否包含另一个字符串的方法

    本文实例讲述了PHP简单判断字符串是否包含另一个字符串的方法.分享给大家供大家参考,具体如下: 在使用PHP判断某字符串中是否包含一个简单的子字符串的时候,我们通常会用到strpos()或者stristr()这两个函数,可是偏偏如果这个字符串的位置如果是在索引0位置,也就是说在要匹配的字符串的最开始,则会出问题. 当然我们还是有解决的方法的,这里就有一个笨办法,但是比较好用,无论中英文,标点符号都适用. 代码如下: function checkStr($str,$target) { $tmpAr

  • Python实现判断字符串中包含某个字符的判断函数示例

    本文实例讲述了Python实现判断字符串中包含某个字符的判断函数.分享给大家供大家参考,具体如下: #coding=utf8 #参数包含两个: #containVar:查找包含的字符 #stringVar:所要查找的字符串 def containVarInString(containVar,stringVar): try: if isinstance(stringVar, str): if stringVar.find(containVar): return True else: return

  • JS判断字符串是否为整数的方法--简单的正则判断

    是否为整数 if(!/^\d+$/.test(str)) alert("不是整数"); } 1.正则表达式 "^\\d+$" //非负整数(正整数 + 0) "^[0-9]*[1-9][0-9]*$" //正整数 "^((-\\d+)|(0+))$" //非正整数(负整数 + 0) "^-[0-9]*[1-9][0-9]*$" //负整数 "^-?\\d+$" //整数 "^\

随机推荐