更改数组Delphi中的特殊字符

Tha*_*vik 6 arrays delphi unicode normalization unicode-normalization

我得到的一些字符串是UTF-8编码,并包含一些特殊字符,如Å¡,Ä',Ä等.我用StringReplace()它来转换为一些普通文本,但我只能转换一种字符.因为PHP还有一个替换字符串的功能,如下所示:如何用PHP中的特殊字符替换特殊字符?,但它支持数组:

<?php
  $vOriginalString = "¿Dónde está el niño que vive aquí? En el témpano o en el iglú. ÁFRICA, MÉXICO, ÍNDICE, CANCIÓN y NÚMERO.";

  $vSomeSpecialChars = array("á", "é", "í", "ó", "ú", "Á", "É", "Í", "Ó", "Ú", "ñ", "Ñ");
  $vReplacementChars = array("a", "e", "i", "o", "u", "A", "E", "I", "O", "U", "n", "N");

  $vReplacedString = str_replace($vSomeSpecialChars, $vReplacementChars, $vOriginalString);

  echo $vReplacedString; // outputs '¿Donde esta el nino que vive aqui? En el tempano o en el iglu. AFRICA, MEXICO, INDICE, CANCION y NUMERO.'
?>
Run Code Online (Sandbox Code Playgroud)

我怎么能在Delphi中这样做?StringReplace不支持数组.

Dav*_*nan 6

function str_replace(const oldChars, newChars: array of Char; const str: string): string;
var
  i: Integer;
begin
  Assert(Length(oldChars)=Length(newChars));
  Result := str;
  for i := 0 to high(oldChars) do
    Result := StringReplace(Result, oldChars[i], newChars[i], [rfReplaceAll])
end;
Run Code Online (Sandbox Code Playgroud)

如果您担心由此引起的所有不必要的堆分配,StringReplace您可以这样写:

function str_replace(const oldChars, newChars: array of Char; const str: string): string;
var
  i, j: Integer;
begin
  Assert(Length(oldChars)=Length(newChars));
  Result := str;
  for i := 1 to Length(Result) do
    for j := 0 to high(oldChars) do
      if Result[i]=oldChars[j] then
      begin
        Result[i] := newChars[j];
        break;
      end;
end;
Run Code Online (Sandbox Code Playgroud)

像这样称呼它:

newStr := str_replace(
  ['á','é','í'],
  ['a','e','i'], 
  oldStr
);
Run Code Online (Sandbox Code Playgroud)

  • @Thalvik如果这回答了你的问题,请标记为.见http://meta.stackexchange.com/questions/5234/how-does-accepting-an-answer-work (3认同)

Jer*_*ers 6

摆脱你的口音被称为规范化.

由于您使用的是Unicode,因此您不仅要在问题中规范化重音字符的短列表.事实上,您正在寻找Unicode 标准化表格 D(NFD)或KD(NFKD),您可以在Windows中进行,当然也可以在Delphi中进行.

这个答案应该让你进入理论方面.

这个Delphi代码这个答案应该让你实现.