怎么能把汉字转换成对应的拼音字母??(100分)

  • 主题发起人 主题发起人 nj_wangzhen
  • 开始时间 开始时间
N

nj_wangzhen

Unregistered / Unconfirmed
GUEST, unregistred user!
我有一字码对照表(就是一个汉字对应一个汉字的首拼音字母)
现在我想将一个药品库中的药品名转换成对应的汉字首拼音
例如:维生素--->vss
我可以先取出一个记录的第一个汉字然后对照字码表找出对应的拼音字母,再取出第二个汉字
再找出对应的拼音字母,然后累加起来,但现在有一个问题,就是药品中有时会有字母
所以我取字符的时侯不知道是取几位(因为一个汉字需取两位字符)
望各位同仁提出自己的思路!!!!(最好有现成的代码供偶参考:) )
 
FUNCTION GETPYBM(HZSTRING:STRING):STRING;
VAR HZLENGTH,I:INTEGER;
BEGIN
RESULT:='';
I:=1;
HZLENGTH:=LENGTH(HZSTRING);
WHILE I<=HZLENGTH DO
BEGIN
IF Windows.IsDBCSLeadByte(byte(HZSTRING)) THEN
BEGIN
RESULT:=RESULT+GETPYINDEXCHAR(HZSTRING+HZSTRING[I+1]);
I:=I+2;
END ELSE
BEGIN
if HZSTRING in ['a'..'z','A'..'Z','0'..'9'] then
RESULT:=RESULT+HZSTRING;
I:=I+1;
END;
END;
END;
 
zhtx老兄,怎么编译到下面这一行编译不下去了
RESULT:=RESULT+GETPYINDEXCHAR(HZSTRING+HZSTRING[I+1]);
Unit1.pas(46): Undeclared identifier: 'GETPYINDEXCHAR'
请明示
 
// 获取指定汉字的拼音索引字母,如:“汉”的索引字母是“H”
function GetPYIndexChar( hzchar:string):char;
begin
case WORD(hzchar[1]) shl 8 + WORD(hzchar[2]) of
$B0A1..$B0C4 : result := 'A';
$B0C5..$B2C0 : result := 'B';
$B2C1..$B4ED : result := 'C';
$B4EE..$B6E9 : result := 'D';
$B6EA..$B7A1 : result := 'E';
$B7A2..$B8C0 : result := 'F';
$B8C1..$B9FD : result := 'G';
$B9FE..$BBF6 : result := 'H';
$BBF7..$BFA5 : result := 'J';
$BFA6..$C0AB : result := 'K';
$C0AC..$C2E7 : result := 'L';
$C2E8..$C4C2 : result := 'M';
$C4C3..$C5B5 : result := 'N';
$C5B6..$C5BD : result := 'O';
$C5BE..$C6D9 : result := 'P';
$C6DA..$C8BA : result := 'Q';
$C8BB..$C8F5 : result := 'R';
$C8F6..$CBF9 : result := 'S';
$CBFA..$CDD9 : result := 'T';
$CDDA..$CEF3 : result := 'W';
$CEF4..$D188 : result := 'X';
$D1B9..$D4D0 : result := 'Y';
$D4D1..$D7F9 : result := 'Z';
else
result := char(0);
end;
end;

我这个函数有缺陷,多音字不处理,想完善就自己改造吧.
 
我试了一下,觉得很不错哦,连我那个字码表都用不着了
可是你说的缺陷是什么呢?能否举一例子说明
我的拼音很烂,我用WB:(
 
后退
顶部