2024年1月31日发(作者:)
y()
函数判断一对象是否初始化,返回布尔值.
表达式 IsEmpty(expression)
实例: <%
Dim i
IsEmpty(i)
%>
返回结果: true
2. GetAt
函数原型:TCHAR GetAt( int nIndex ) const;
函数返回值:字符中第nIndex个字符(从0开始).
Header: atlcoll.h
注意:nIndex的最大值可由GetUpperBound()得到。若nIndex小于0或大于最大值,将返回错误。
3. isdigit
isdigit
原型:extern int isdigit(char c);
用法:#include
功能:判断字符c是否为数字
说明:当c为数字0-9时,返回非零值,否则返回零。
附加说明 此为宏定义,非真正函数。
相关函数:isalnum,isalpha,isxdigit,iscntrl,isgraph,isprint,ispunct,isspace
4. isalnum
原型:extern int isalnum(int c);
用法:#include
功能:判断字符变量c是否为字母或数字
说明:当c为数字0-9或字母a-z及A-Z时,返回非零值,否则返回零。
5. isalpha
函数:isalpha
原型:int isalpha(int ch)
用法:头文件加入#include
功能:判断字符ch是否为英文字母,当ch为英文字母a-z或A-Z时,在标准c中相当于使用“isupper(ch)||islower(ch)”做测试,返回非零值,否则返回零。
PS:{
isupper
原型:extern int isupper(int c);
头文件:
功能:判断字符c是否为大写英文字母
说明:当参数c为大写英文字母(A-Z)时,返回非零值,否则返回零。
附加说明: 此为宏定义,非真正函数。
islower
islower(测试字符是否为小写字母)
相关函数
isalpha,isupper
表头文件
#include
定义函数
int islower(int c)
函数说明
检查参数c是否为小写英文字母。
返回值
若参数c为小写英文字母,则返回TRUE,否则返回NULL(0)。
附加说明:此为宏定义,非真正函数。
}
示例:
/*本函数运行环境Visual C++ 6.0,测试结果 :通过*/
#include
#include
int main(void)
{
char ch;
int total;
total=0;//初始化
/*统计字母块*/
do
{
ch=getchar();
if(isalpha(ch)!=0)
total++;
}while(ch!='.');//结束符号为 .
printf("The total of letters is %d n",total);
return 0;
}
/*运行结果*/
输入:123456我am侯云江.
输出:The total of letters is 2
6.TCHAR
因为C++支持两种字符串,即常规的ANSI编码(使用""包裹)和Unicode编码(使用L""包裹),这样对应的就有了两套字符串字符串处理函数,比如:strlen和wstrlen,分别用于处理两种字符串
微软将这两套字符集及其操作进行了统一,通过条件编译(通过_UNICODE和UNICODE宏)控制实际使用的字符集,这样就有了_T("")这样的字符串,对应的就有了_tcslen这样的函数
为了存储这样的通用字符,就有了TCHAR:
当没有定义_UNICODE宏时,TCHAR = char,_tcslen
= strlen
当定义了_UNICODE宏时,TCHAR = wchar_t , _tcslen
= wstrlen
当我们定义了UNICODE宏,就相当于告诉了编译器:我准备采用UNICODE版本。这个时候,TCHAR就会摇身一变,变成了wchar_t。而未定义UNICODE宏时,TCHAR摇身一变,变成了unsigned char 。这样就可以很好的切换宽窄字符集。
tchar可用于双字节字符串,使程序可以用于中日韩等国 语言文字处理、显示。使编程方法简化。
7. GetText函数
返回数据窗口控件中 悬浮在当前行列之上的编辑框中的文本。在用户修改数据窗口中某项的值时,实际上首先在悬浮 在当前项上的编辑框中进行修改 , 当用户移动输入焦点或程序中使用 AcceptText()函数接收用户输入时,用户修改的数据通过有效性规则验证后放入数据窗口的主缓冲区中。
语法:
t( )
参数:
dwcontrol 数据窗口控件名
返回值:
String 函数执行成功时返回悬浮在数据窗口dwcontrol
当前行列之上的编辑框中的文本,该文本值或许能、或许不能通过各种有效性检查,即或许可以接收为当前项的值,或许不能接收。如果数据窗口中没有当前项,则GetText()函数返回空字符串 "" ,如果dwcontrol 的值为NULL ,则GetText()函数返回NULL。
编辑本段用法:
显示在数据窗口中的各个数据项的值保存在数据窗口的主缓冲区中。当用户编辑某项的值时,系统自动把该值传送到 漂浮 在该项之上的编辑框中,供用户进行修改。
当用户移动输入焦点或程序中使用 AcceptText()函数接收用户输入后 用户修改的数据通过有效性规则验证时放入数据窗口的主缓冲区中。
在数据窗口控件的ItemChanged 或ItemError 事件中不需要调用GetText()函数来得到编辑框中用户输入或修改的内容 ,此时,可以使用这些事件的data 参数得到该内容;要得到数据窗口缓冲区中某项的值 , 使用与相应列的数据类型相匹配的 GetItem 系列函数 。
编辑本段示例:
下面的语句得到数据窗口控件中 漂浮 在当前数据项之上的编辑框的内容并将其保存在变量LName 中
string LName
LName = dw_t()
程序例:
#include
char buffer[4096];
int main(void)
{
int i;
clrscr();
for (i = 0; i <= 20; i++)
cprintf("Line #%drn", i);
gettext(1, 1, 80, 25, buffer);
gotoxy(1, 25);
cprintf("Press any key to ");
getch();
clrscr();
gotoxy(1, 25);
cprintf("Press any key to ");
getch();
puttext(1, 1, 80, 25, buffer);
gotoxy(1, 25);
cprintf("Press any key ");
getch();
return 0;
}
8.
SetWindowText
函数功能:该函数改变指定窗口的标题栏的文本内容(如果窗口有标题栏)。如果指定窗口是一个控件,则改变控件的文本内容。然而,SetWindowText函数不改变其他应用程序中的控件的文本内容。
函数原型:BOOL SetWindowText(HWND hwnd,LPCTSTR
lpString);
参数:
hWnd:要改变文本内容的窗口或控件的句柄。
lpString:指向一个空结束的字符串的指针,该字符串将作为窗口或控件的新文本。
返回值:如果函数成功,返回值为非零;如果函数失败,返回值为零。若想获得更多错误信息,请调用GetLastError函数。
备注:如果目标窗口属于当前进程,SetWindowText函数会使WM_SETTEXT消息发送给指定的窗口或控件。然而,如果控件是以WS_CAPTION风格创建的列表框控件,SetWindowText函数将为控件设置文本,而不是为列表项设置文本。
SetWindowText函数不扩展tab字符(ASCII代码0×09),Tab字符以字符‘}’来显示。
9.进度条颜色设置
在VC里想改变进度条颜色,在网上找了很多方法,都很麻烦,觉得很郁闷。后来想起在用VB做时,增经用API实现过,很简单。后来再一查,原来是SendMessage这个函数,几经试验,终于成功,高兴,与大家分享!!!!
代码如下:
m_ssage(PBM_SETBKCOLOR, 0,
RGB(0, 0, 255));//背景色为蓝色
m_ssage(PBM_SETBARCOLOR,
0, RGB(255, 0, 0));//前景色为红色
10. VC++中Format函数详解
函数声明
function Format(const Format: string; const Args: array
of const): string; overload;
函数功能
事实上Format方法有两种形式,另外一种是三个参数的,主要区别在于它是线程安全的, 但并不多用,所以这里只对第一个介绍。Format参数是一个格式字符串,用于格式化Args里面的值的。Args是一个变体数组,即它里面可以有多个参数,而且每个参数可以不同。 例如:
Format("my name is %6s","wind");
返回的是:my name is wind
函数参数
Format里面可以写普通的字符串,比如"my name is" ,但有些格式指令字符具有特殊意义,比如"%6s"
格式指令具有以下的形式: "%" [index ":"] ["-"]
[width] ["." prec] type
它是以"%"开始,而以type结束,type表示一个具体的类型。中间是用来格式化type类型的指令字符,是可选的。
各个参数的含义与用途如下;
[type]
type参数可选的类型有d,u,f,e,g,n,m,p,s,x.
1) d 十进制数,表示一个整型值,u 和d一样是整型值,但它是无符号的,而如果它对应的值是负的,则返回时是一个2的32次方减去这个负数的绝对值 。
例如:Format("this is %u",-2);
返回的是:this is 4294967294
2)f 对应浮点数
3)e科学表示法,对应整型数和浮点数
例如:Format("this is %e",-2.22);
返回的是:this is -2.220000E+000
4)g 这个只能对应浮点型,且它会将值中多余的数去掉
例如:Format("this is %g",02.200);
返回的是:this is 2.2
5)n 只能对应浮点型,将值转化为号码的形式,看一个例子就明白了
例如:Format("this is %n",4552.2176);
返回的是:this is 4,552.22
注意:一是,只表示到小数后两位
二是,即使小数没有被截断,它也不会也像整数部分一样有逗号来分开的
6)m 钱币类型,但关于货币类型有更好的格式化方法,这里只是简单的格式化,另外它只对应于浮点值
例如:Format("this is %m",9552.21);
返回的是:this is ¥9,552.21
7)p 对应于指针类型,返回的值是指针的地址,以十六进制的形式来表示
例如: Format("this is %p",p);
返回的是:this is 0012F548
8)s 对应字符串类型
9)x 必须是一个整形值,以十六进制的形式返回
例如:Format("this is %X",15);
返回的是:this is F
下面介绍格式化Type的指令:
[index ":"] :index指示Args中参数显示的顺序 。
例如:Format("this is %d %d",12,13);
其中第一个%d的索引是0,第二个%d是1,所以字符显示的时候,是这样:this is 12 13
若定义为:Format("this is %1:d %0:d",12,13);
那么返回的字符串就变成了:this is 13 12
若定义为:Format("%d %d %d %0:d %d", 1, 2, 3, 4) ;
那么将返回的是:1 2 3 1 2
若想返回的是1 2 3 1 4,必须这样定义:Format("%d %d %d %0:d %3:d", 1, 2, 3, 4) ;
注意:索引不能超出Args中的个数,不然会引起异常。
例如:Format("this is %2:d %0:d",12,13);
由于Args中只有12 13 两个数,所以Index只能是0或1,这里为2就错了 。
[width] :指定将被格式化的值占的宽度。
例如:Format("this is %4d",12);
返回的是:this is 12
如果Width的值小于参数的长度,则没有效果。
例如:Format("this is %1d",12);
返回的是:this is 12
["-"] :这个指定参数向左对齐,和[width]合在一起最可以看到效果。
例如:Format("this is %-4d,yes",12);
返回的是:this is 12 ,yes
["." prec] :指定精度,对于浮点数效果最佳。
例如:Format('this is %.2f,1.1234);
返回的是: this is 1.12
又如:Format('this is %.7f,1.1234);
返回的是: this is 1.1234000
而对于整型数,如果prec比如整型的位数小,则没有效果,反之比整形值的位数大,则会在整型值的前面以0补之。
例如:Format('this is %.7d,1234);
返回的是:this is 0001234
对于字符型,刚好和整型值相反,如果prec比字符串型的长度大,则没有效果,反之比字符串型的长度小,则会截断尾部的字符。
例如:Format('this is %.2s,1234);
返回的是:this is 12
之前说过的例子:Format("this is %e",-2.22);
返回的是:this is -2.220000E+000
若这样:Format('this is %.2e',[-2.22]); 就可以解决了!
编辑本段二 FormatDateTime的用法
他的声明为:
function FormatDateTime(const Format: string;
DateTime: TDateTime): string;
overload;
当然和Format一样还有一种,但这里只介绍常用的第一种
Format参数是一个格式化字符串。DateTime是时间类型。返回值是一种格式化后的
字符串
重点来看Format参数中的指令字符
c 以短时间格式显示时间,即全部是数字的表示
FormatdateTime('c',now);
输出为:2004-8-7 9:55:40
d 对应于时间中的日期,日期是一位则显示一位,两位则显示两位
FormatdateTime('d',now);
输出可能为1~31
dd 和d的意义一样,但它始终是以两位来显示的 FormatdateTime('dd',now);
输出可能为01~31
ddd 显示的是星期几
FormatdateTime('ddd',now);
输出为: 星期六
dddd 和ddd显示的是一样的。
但上面两个如果在其他国家可能不一样。
ddddd 以短时间格式显示年月日
FormatdateTime('ddddd',now);
输出为:2004-8-7
dddddd 以长时间格式显示年月日
FormatdateTime('dddddd',now);
输出为:2004年8月7日
e/ee/eee/eeee 以相应的位数显示年
FormatdateTime('ee',now);
输出为:04 (表示04年)
m/mm/mmm/mmmm 表示月
FormatdateTime('m',now);
输出为:8
FormatdateTime('mm',now);
输出为 08
FormatdateTime('mmm',now);
输出为 八月
FormatdateTime('mmmm',now);
输出为 八月
和ddd/dddd 一样,在其他国家可能不同
yy/yyyy 表示年
FormatdateTime('yy',now);
输出为 04
FormatdateTime('yyyy',now);
输出为 2004
h/hh,n/nn,s/ss,z/zzz 分别表示小时,分,秒,毫秒
t 以短时间格式显示时间
FormatdateTime('t',now);
输出为 10:17
tt 以长时间格式显示时间
FormatdateTime('tt',now);
输出为10:18:46
ampm 以长时间格式显示上午还是下午
FormatdateTime('ttampm',now);
输出为:10:22:57上午
大概如此,如果要在Format中加普通的字符串,可以用双引号隔开那些
特定义的字符,这样普通字符串中如果含特殊的字符就不会被显示为
时间格式啦:
FormatdateTime('"today is" c',now);
输出为:today is 2004-8-7 10:26:58
时间中也可以加"-"或""来分开日期:
FormatdateTime('"today is" yy-mm-dd',now);
FormatdateTime('"today is" yymmdd',now);
输出为: today is 04-08-07
也可以用":"来分开时间
FormatdateTime('"today is" hh:nn:ss',now);
输出为:today is 10:32:23
编辑本段三.FormatFloat的用法
常用的声明:
function FormatFloat(const Format: string; Value:
Extended): string; overload;
和上面一样Format参数为格式化指令字符,Value为Extended类型
为什么是这个类型,因为它是所有浮点值中表示范围最大的,如果传入该方法的参数
比如Double或者其他,则可以保存不会超出范围。
关键是看Format参数的用法
0 这个指定相应的位数的指令。
比如:FormatFloat('000.000',22.22);
输出的就是022.220
注意一点,如果整数部分的0的个数小于Value参数中整数的位数,则没有效果
如:FormatFloat('0.00',22.22);
输出的是:22.22
但如果小数部分的0小于Value中小数的倍数,则会截去相应的小数和位数
如:FormatFloat('0.0',22.22);
输出的是:22.2
也可以在整数0中指定逗号,这个整数位数必须大于
3个,才会有逗号出句
FormatFloat('0,000.0',2222.22);
输出是:2,222.2
如果这样FormatFloat('000,0.0',2222.22);
它的输出还是:2,222.2
注意它的规律
# 和0的用法一样,目前我还没有测出有什么不同。
FormatFloat('##.##',22.22);
输出是:22.00
E 科学表示法,看几个例子大概就明白了
FormatFloat('0.00E+00',2222.22);
输出是 2.22E+03
FormatFloat('0000.00E+00',2222.22);
输出是 2222.22E+00
FormatFloat('00.0E+0',2222.22);
22.2E+2
明白了吗,全靠E右边的0来支配的。
编辑本段vb中的format函数
返回 Variant (String),其中含有一个表达式,它是根据格式表达式中的指令来格式化的。
语法
Format(expression[, format[, firstdayofweek[,
firstweekofyear]]])
Format 函数的语法具有下面几个部分:
部分
expression
format
firstdayofweek
firstweekofyear
设置值
firstdayofweek 参数有下面设置:
常数 值 说明
说明
必要参数。任何有效的表达式。
可选参数。有效的命名表达式或用户自定义格式表达式。
可选参数。常数,表示一星期的第一天。
可选参数。常数,表示一年的第一周。
vbUseSystem 0
使用 NLS API 设置。
VbSunday
vbMonday
vbTuesday
1
星期日(缺省)
2
星期一
3
星期二
vbWednesday 4
星期三
vbThursday
vbFriday
vbSaturday
5
星期四
6
星期五
7
星期六
firstweekofyear 参数有下面设置:
常数 值 说明
vbUseSystem 0
使用 NLS API 设置。
vbFirstJan1
vbFirstFourDays
VbFirstFullWeek
说明
格式化
数字
作法
使用预先定义的命名数值格式或创建用户自定义数值格式。
1
从包含一月一日的那一周开始(缺省)。
2
从本年第一周开始,而此周至少有四天在本年中。
从本年第一周开始,而此周完全在本年中。
3
日期和时使用预先定义的命名日期/时间格式或创建用
间
日期和时间序数
字符串
户自定义日期/时间格式。
使用日期和时间格式或数值格式。
创建自定义的字符串格式。
如果在格式化数字时没有指定 format,Format 会提供与 Str 函数类似的功能,尽管它是国际化的。然而,以
Format 作用在正数上不会保留正负号空间,而以 Str 的话则会。
如果要格式化一个没有本地化的数值字符串,应该使用一个用户自定义的数值格式,以保证得到需要的外观。
注意 如果 Calendar 属性设置是Gregorian ,并且format 指定了日期格式,那么,提供的 expression 必须是Gregorian 。如果Visual Basic Calendar 属性设置是 Hijri,则提供的的 expression 必须是Hijri 。
如果日历是Gregorian,则 format 表达式的意义没有改变。如果日历是Hijri ,则所有的日期格式符号(例如,dddd, mmmm, yyyy )有相同的意义,这些意义只应用于Hijri 日历。格式符号保持英文,用于文本显示的符号(例如,AM 和PM )显示与该符号有关的字符串(英文或阿拉伯数字)。当日历是Hijri 时,一些符号的范围会改变。
符号
范围
ww
mmm 显示完整的月份名y 1-yyyy 1d 1-dd 130 -30
1-51称(Hijri 月份名称无缩写35500-966 形式)
6
编辑本段Format 函数示例
本示例显示用 Format 函数做格式化输出的不同用法。对于日期分隔号(/),时间分隔号(:),以及 AM/ PM 等文本而言,其真正的显示格式会因计算机上的国际标准不同而有所差异。在开发阶段,日期与时间是以短日期的格式,配合代码的国际标准来显示的。而在运行时,短日期则是根据系统的国际标准而定,而系统的国际标准和代码的国际标准可能并不相同。本示例中是假设国际标准为
English/United States。
MyTime 及 MyDate 在开发环境下,使用系统的短日期设置显示出来的。
Dim MyTime, MyDate, MyStrMyTime =
#17:04:23#MyDate = #January 27, 1993#' 以系统设置的长时间格式返回当前系统时间。MyStr = Format(Time, "Long
Time")' 以系统设置的长日期格式返回当前系统日期。MyStr = Format(Date, "Long Date")MyStr = Format(MyTime,
"h:m:s") ' 返回 "17:4:23"。MyStr = Format(MyTime,
"hh:mm:ss AMPM") ' 返回 "05:04:23 PM"。MyStr =
Format(MyDate, "dddd, mmm d yyyy") ' 返回 "Wednesday,
Jan 27 1993"。' 如果没有指定格式,则返回字符串。MyStr
= Format(23) ' 返回 "23"。' 用户自定义的格式。MyStr =
Format(5459.4, "##,##0。00") ' 返回 "5,459.40"。MyStr =
Format(334。9, "###0。00") ' 返回 "334.90"。MyStr =
Format(5, "0。00%") ' 返回 "500.00%"。MyStr =
Format("HELLO", "<") ' 返回 "hello"。MyStr = Format("This is
it", ">") ' 返回 "THIS IS IT"。
11.AfxMessageBox的函数原型
int AfxMessageBox( LPCTSTR lpszText, UINT nType =
MB_OK, UINT nIDHelp = 0 );
int AFXAPI AfxMessageBox( UINT nIDPrompt, UINT
nType = MB_OK, UINT nIDHelp = (UINT) –1 );
在第一种形式中,lpszText表示在消息框内部显示的文本,消息框的标题为应用程序的可执行文件名(如Hello)。在第二种形式中,nIDPrompt为要显示的文本字符串在字符串表中的ID。函数调用时会自动从字符串表中载入字符串并显示在消息框中。nType为消息框中显示的按钮风格和图标风格的组合,可以采用|(或)操作符组合各种风格。
按钮风格
MB_ABORTRETRYIGNORE 消息框中显示Abort、Retry、Ignore按钮
MB_OK 显示OK按钮
MB_OKCANCEL 显示OK、Cancel按钮
MB_RETRYCANCEL 显示Retry、Cancel按钮
MB_YESNO 显示Yes、No按钮
MB_YESNOCANCEL 示Yes、No、Cancel按钮
图标风格
MB_ICONINFORMATION 显示一个i图标,表示提示
MB_ICONEXCLAMATION 显示一个惊叹号,表示警告
MB_ICONSTOP 显示手形图标,表示警告或严重错误
MB_ICONQUESTION 显示问号图标,表示疑问
使用时,可以只调用AfxMessageBox(LPCTSTR lpszText);这样默认风格为AfxMessageBox(LPCTSTR lpszText,MB_OK|MB_ICONEXCLAMATION );
编辑本段AfxMessageBox()与MessageBox()的区别
与AfxMessageBox类似的函数MessageBox,它是CWnd的类成员函数:
int MessageBox( LPCTSTR lpszText,LPCTSTR lpszCaption
= NULL,UINT nType = MB_OK );
两个函数的区别:AfxMessageBox比MessageBox简单一些,因为它是一个全局函数所以不需要对应的一个窗口
类,但是不能控制消息框标题,常用于调试程序时的内部数据输出或警告;MessageBox比较正式,常用在要提交的应用程序版本中,可以控制标题内容而不必采用含义不明的可执行文件名为标题。
举例:
AfxMessageBox("Are you
sure?",MB_YESNO|MB_ICONQUESTION);
int a = MessageBox(TEXT("是否确认删除?"),TEXT("Warning!!"),4);
if(a==6)
AfxMessageBox("Yes");
else
AfxMessageBox("No");
(其中#define IDYES 6 #define IDNO 7)
主要区别:
eBox 如果在非CWnd类中使用则是API函数,使用起来非常不便,必须指定标题和样式
否则使用CWnd类的函数,只需一个内容参数就可以了,AfxMessageBox和CWnd类成员函数类似,使用起来很方便,因为是Afx 基于框架的函数
eBox是模态对话框,你不进行确认时程序不往下运行,它会阻塞你当前的线程为,除非你程序是多线
程的程序,否则只有等待模态对话框被确认
3、如果用MFC的话,请尽量使用afxmessagebox,因为这个全局的对话框最安全,也最方便。
但是在WIN32 SDK的情况下只能使用MESSAGEBOX。
;
}
{
}
本文发布于:2024-01-31 07:43:39,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170665822026798.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |