展开全部
1. 可以用正则表达式匹配中文 [\u4e00-\u9fa5]
2. 字符对应的编码值在,19968和40869之间的为中文
string name = "nihao高峰";
int currentcode=-1;
for (int i = 0; i < name.Length; i++)
{
currentcode=(int)name[i];
if (currentcode >19968&¤tcode < 40869)
{
Console.WriteLine(name[i].ToString());
}
}
类似这样去拿就可以解决问题了
2. 字符对应的编码值在,19968和40869之间的为中文
string name = "nihao高峰";
int currentcode=-1;
for (int i = 0; i < name.Length; i++)
{
currentcode=(int)name[i];
if (currentcode >19968&¤tcode < 40869)
{
Console.WriteLine(name[i].ToString());
}
}
类似这样去拿就可以解决问题了
展开全部
方法应该是有很多种的,也得看你的字符串中具体是哪样的字符,如果什么都有,可以把你的字符串编码为GB2312的byte数组(Encoding.GetEncoding("GB2312").GetBytes(汉字)),在GB2312中,每个汉字及符号以两个字节来表示,编码为byte数组后,是偶数个,普通字母和数字式一个字节。第一个字节称为“高位字节”,第二个字节称为“低位字节”。在GB2312编码中,汉字的区码十进制是从176到247,位码是从161到255,如果满足了这个要求,那就是一个汉字了
不知道明白没,试试就很清楚了
不知道明白没,试试就很清楚了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
很难的 因为全角的符号也是占用两个字节
所以...........
所以...........
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询