我现在的需求是把表格的单元格中的字符串取出来,如果是数字就转为int ,如果是中文后者其他的就置0 。
我的解决思路是先取出字符串,再一个字符一个字符地匹配ASCII码
CString sf = _T(" 柳 / 1A2A3B!4c5】我+6爱7中8国9a0");
/*string sd;
sd.matches("-?\\d+");*/
int length = sf.GetLength();
for (int j = 0; j < length; j++)
{
if (sf[j] <= 57&& sf[j] >= 48)
{
MessageBox(_T("数字"));
}
else if(sf[j] <= 90 && sf[j] >= 65)
{
MessageBox(_T("大写字母"));
}
else if (sf[j] <= 122 && sf[j] >= 97)
{
MessageBox(_T("小写字母"));
}
else if (sf[j] ==32)
{
MessageBox(_T("这是一个空格"));
}
else
{
MessageBox(_T("中文或其它符号"));
}
}
写了一个判断字符串能不能转成int的函数
BOOL IsConvertableToInt( CString & strName)
{
BOOL flag = true;
int count = 0;
int length = strName.GetLength();
if (length > 11)
{
flag = false;
}
else if (length == 0)
{
flag = false;
}
else
{
for (int j = 0; j < length; j++)
{
if (strName[j] > 57 || strName[j] < 48)
{
count++;
if (count > 0)
{
flag = false;
break;
}
}
}
}
return flag;
}