// 读出0~9999范围的数 void read_group(const char *str, char **buf, int len, UINT flags) { char *buf_start = *buf; BOOL zero = TRUE; // 当前是否为连续的0 BOOL zero_only = TRUE; // 字符串中是否只出现了0 int d, place; int i; static const char *list = "零一二三四五六七八九";
if (flags & RG_ZEROLEADING) { /* 如果不足1000, 则始终以"零"字开头 */ zero = FALSE; if (len <= 3) { append(buf, "零"); zero = TRUE; } }
/* 遍历字符串 */ for (i = 0; i < len; i++) { // 忽略连续的0 if (zero) { if (str[i] == '0') continue; else zero = FALSE; // 出现了非0数字时, 停止忽略 }
d = str[i] - '0'; // 当前位数字 place = len - i; // 当前为第几位 if (d > 0) zero_only = FALSE; // 字符串中出现了非零数字 if (!(d == 1 && place == 2 && *buf == buf_start)) { strncpy(*buf, list + 2 * d, 2); // 输出当前数字的汉字形式 *buf += 2; }
if (d != 0) // 不允许"零千"、"零百"等这样的说法出现 { switch (place) { case 4: append(buf, "千"); break; case 3: append(buf, "百"); break; case 2: append(buf, "十"); break; } } else zero = TRUE; // 忽略接下来的0 } if (*buf == buf_start) // 若buf为空字符串 { if (!(flags & RG_IGNOREZEROVALUE)) // RG_IGNOREZEROVALUE要求0000对应空字符串 append(buf, "零"); // 最终内容为"零" } else if (zero && (!zero_only || ((flags & RG_ZEROLEADING) && (flags & RG_IGNOREZEROVALUE)))) *buf -= 2; // 去掉字符串末尾多余的"零", 如"四十零", zero表示字符串以"零"字结尾 // 一般情况下, 如果整个字符串只有一个"零"字(zero_only), 就不去掉 // 但如果同时设置了RG_ZEROLEADING和RG_IGNOREZEROVALUE选项, 那么即使字符串只有一个"零"字也要将其去掉, 变成空字符串
**buf = '\0'; }
|