本人记忆力不好,所以把这些小知识都在这里记录下,方便以后使用,也方便需要的朋友~
在GB2321编码中,中文的编码范围是:0xB0A1~0xF7FE,所以代码如下~
#include <string>
#include <iostream>
using namespace std;
string RemoveChinese(string str)
{
char strR[100] = "";
int nDest = 0;
for(int nIndex = 0; nIndex < str.length(); ++nIndex )
{
unsigned char chStr = str[nIndex];//这里一定要用无符号的,否则中文字符比较也会通过~
if( (chStr >= 0xb0 && chStr <= 0xf7) || ( chStr >= 0xa1 && chStr <= 0xfe ) ) continue;
strR[nDest] = str[nIndex];
nDest++;
}
return strR;
}
void main()
{
string str;
cout<<"请输入需要筛选的字符(结束程序请输入a):"<<endl;
cin>>str;
while( str != "a" )
{
cout<<"筛选后字符为:"<<RemoveChinese(str)<<endl;
cout<<"请输入需要筛选的字符(结束程序请输入a):"<<endl;
cin>>str;
}
return;
}
运行结果:
本文介绍了一个简单的C++程序,该程序能够从输入字符串中移除GB2312编码的中文字符。通过遍历字符串并检查每个字符是否位于中文编码范围内来实现这一功能。
4145





