isupper() 判断一个字符是否是大写字母
int isupper ( int c );
isupper() 函数用来检测一个字符是否是大写字母。在默认情况下,大写字母包括:
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
标准 ASCII 编码共包含了 128 个字符,不同的字符属于不同的分类,我们在 <ctype.h> 头文件中给出了详细的列表。
参数
-
c
要检测的字符。它可以是一个有效的字符(被转换为 int 类型),也可以是 EOF(表示无效的字符)。
返回值
返回值为非零(真)表示c
是大写字母,返回值为零(假)表示c
不是大写字母。
实例
判断字符串中的字符是否是大写字母,如果是,那么转换为小写字母。#include <stdio.h> #include <ctype.h> int main () { int i = 0; char str[] = "C C++ Java Python.\n"; char c; while(str[i]) { c = str[i]; if(isupper(c)) c = tolower(c); putchar(c); i++; } return 0; }运行结果:
c c++ java python.
关于大写字母
人们通常认为只有"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() 返回“真”的字符。