<wctype.h>
-- 函数
阅读:0
作者:严长生
iswlower() 判断一个宽字符是否是小写字母
int iswlower (wint_t c);
iswlower() 函数用来检测一个宽字符是否是小写字母。iswlower() 是 islower()(位于<ctype.h>中)的宽字符版本:如果参数 wc 能够被 wctob() 转换为单个字节的形式,并且转换后的字符使用 islower() 检测返回“真”(非零值),那么 iswlower() 也一定会将 wc 判定为小写字母。
参数
-
wc
要检测的宽字符。它可以是一个有效的宽字符(被转换为 wint_t 类型),也可以是 WEOF(表示无效的宽字符)。
返回值
返回值为非零(真)表示wc
是小写字母,返回值为零(假)表示wc
不是小写字母。
实例
判断字符串中的字符是否是小写字母,如果是,那么将它转换为大写字母。#include <stdio.h> #include <wctype.h> int main () { int i = 0; wchar_t str[] = L"C C++ Java Python GoLang\n"; wchar_t c; while (str[i]) { c = str[i]; if (iswlower(c)) c = towupper(c); putwchar (c); i++; } return 0; }运行结果:
C C++ JAVA PYTHON GOLANG
关于小写字母
人们通常认为只有"abc...xyz"
才是小写字母,其实这是不对的。小写字母并不是固定的,不同的语言文化可能会包含不同的小写字母,例如在“简体中文”环境中,拼音ü
、拉丁文àáâãäåçö
、希腊文σωδψφ
(数学物理公式中常用希腊字母)等都将成为小写字母。我们可以通过 setlocale() 函数改变程序的地域设置,让程序使用不同的字符集,从而支持不同的语言文化。
在默认的地域设置(默认为
"C"
)中,C语言通常使用 ASCII 编码,能较好地支持英文,此时小写字母包括:
a b c d e f g h i j k l m n o p q r s t u v w x y z
在其它地域设置中,可能会使用 GBK(简体中文)、BIG5(繁体中文)、Shift-JIS(日文)、Unicode(世界统一码) 等更加复杂的编码,它们包含了更多的小写字母。
也就是说,一个字符是否是小写字母和程序的地域设置有关,不同的地域设置会包含不同的小写字母。
但是有一个原则,被视为小写字母的字符一定不能是 iscntrl()、isdigit()、ispunct()、isspace() 返回“真”的字符。
【实例】在简体中文环境下检测小写字母。
#include <wchar.h> #include <wctype.h> #include <locale.h> int main () { int i=0; int cx=0; wchar_t str[] = L"拼音ü、拉丁文àáâãäåçö、希腊文σωδψφ"; setlocale(LC_ALL, "zh_CN.UTF-8"); //设置为简体中文,使用 UTF-8 编码 //在 Windows 下可以写作 setlocale(LC_ALL, ""); 或者 setlocale(LC_ALL, "chs"); //在 Linux 下可以写作 setlocale(LC_ALL, ""); 或者 setlocale(LC_ALL, "zh_CN.UTF-8"); //在 Mac OS 下可以写作 setlocale(LC_ALL, "zh_CN"); 或者 setlocale(LC_ALL, "zh_CN.UTF-8"); while (str[i]) { if (iswlower(str[i])) cx++; i++; } wprintf (L"There are %d wide characters are lowercase.\n", cx); return 0; }运行结果:
There are 14 wide characters are lowercase.