原创 C++字符串,数字相互转换

2007-7-30 23:14 11655 10 10 分类: 软件与OS

一.将CString转为CTime的几种方法


CString   timestr   =   "2000年04月05日";  
  int   a,b,c   ;  
  sscanf(timestr.GetBuffer(timestr.GetLength()),"%d年%d月%d日",&a,&b,&c);  
  CTime   time(a,b,c,0,0,0);    


--------or - ---------------------

 CString   s("2001-8-29   19:06:23");  
  int   nYear,   nMonth,   nDate,   nHour,   nMin,   nSec;  
  sscanf(s,   "%d-%d-%d   %d:%d:%d",   &nYear,   &nMonth,   &nDate,   &nHour,   &nMin,   &nSec);  
  CTime   t(nYear,   nMonth,   nDate,   nHour,   nMin,   nSec);

---- or ------------------------
CString   timestr   =   "2000年04月05日";  
  int   year,month,day;  
  BYTE   tt[5];  
  //get   year  
  memset(tt,   0,   sizeof(tt));  
  tt[0]   =   timestr[0];  
  tt[1]   =   timestr[1];  
  tt[2]   =   timestr[2];  
  tt[3]   =   timestr[3];  
  year=   atoi((char   *)tt);  
   
  //get   month  
  memset(tt,   0,   sizeof(tt));  
  tt[0]   =   timestr[6];  
  tt[1]   =   timestr[7];  
  month   =   atoi((char   *)tt);  
   
  //get   day  
  memset(tt,   0,   sizeof(tt));  
  tt[0]   =   timestr[10];  
  tt[1]   =   timestr[11];  
   
  CTime   time(year,month,day,0,0,0);


从上面来看,很明显使用sscanf()函数的优势.


 


二.将CTIme转换为CString的方法:


CTime  tmSCan = CTime::GetCurrentTime();


CString szTime = tmScan.Format("'%Y-%m-%d %H:%M:%S'");


这样得到的日期时间字符串就是以"2006-11-27 23:30:59"的格式.这是不是很方便呢?


 //取得CTime中的日期
 CString cstrDate = tmScan.Format("%Y-%m-%d");


 //取得CTime中的时间
 CString cstrTime = tmScan.Format("%H:%M-%S");


          sprintf还有个不错的表妹:strftime,专门用于格式化时间字符串的,用法跟她表哥很像,也是一大堆格式控制符,只是毕竟小姑娘家心细,她还要调用者指定缓冲区的最大长度,可能是为了在出现问题时可以推卸责任吧。这里举个例子:


 


 更多更好的sprintf()函数说明参考:《spirntf,你知道多少?》


http://blog.csdn.net/steedhorse/archive/2005/03/25/330206.aspx


time_t t = time(0);





      //产生"YYYY-MM-DD hh:mm:ss"格式的字符串。





char s[32];





strftime(s, sizeof(s), "%Y-%m-%d %H:%M:%S", localtime(&t));





sprintfMFC中也能找到他的知音:CString::FormatstrftimeMFC中自然也有她的同道:CTime::Format,这一对由于从面向对象哪里得到了赞助,用以写出的代码更觉优雅。


三,字符串转换为数值类型


将字符串"20.0E6"转换为数字


1,sscanf("20.0e5","%d",&x);


2,atof("20.0E6");


许多人用atoi(), atof() 和这个“家族”中的其它函数. 它们方便应用,但是有一个重要的缺点:
在转换失败和转换字符串"0"时都返回0, 这样使得一致性错误检查变得几乎不可能。 为了完整性我们给出了小段代码:


 


代码:
--------------------------------------------------------------------------------
   const char* str_int = "777";
   const char* str_float = "333.3";
   int i = atoi(str_int);
   float f = atof(str_float);
--------------------------------------------------------------------------------



一个更好的办法:


更有一点复杂, 更遗一致的办法是利用sscanf()


代码:
--------------------------------------------------------------------------------
   const char* str_int = "777";
   const char* str_float = "333.3";
   int i;
   float f;
   if(EOF == sscanf(str_int, "%d", &i)){
      //错误
   }
   if(EOF == sscanf(str_float, "%f", &f)){
      //错误
   }
--------------------------------------------------------------------------------


Since sscanf() takes a const char* parameter, you can directly use a CString with it:
因为sscanf()用const char* 作为参数, 所以你可以直接用CString作参数:


代码:
--------------------------------------------------------------------------------
   CString str_int("777");
   if(EOF == sscanf(str_int, "%d", &i)){
      //error
   }
--------------------------------------------------------------------------------


小心格式描述符(如本例中的"%d")。 sscanf()没有办法检查格式描述符与传递变量的类型匹配与否。如果不匹配你将得到不可预期的结果。 同样注意sscanf()可以一次从字符串中提取一个或多个数值。 详细信息请查阅MSDN。


 


C++ 方法



如下的例子展示了利用标准C++类的来完成这个任务的模板函数


代码:
--------------------------------------------------------------------------------
#include <string>
#include <sstream>
#include <iostream>


template <class T>
bool from_string(T &t,
                 const std::string &s,
                 std::ios_base & (*f)(std::ios_base&))
{
   std::istringstream iss(s);
   return !(iss>>f>>t).fail();
}


int main()
{
   int i;
   float f;
   // from_string()的第三个参数应为如下中的一个
   // one of std::hex, std::dec 或 std::oct
   if(from_string<int>(i, std::string("ff"), std::hex)){
      std::cout<<i<<std::endl;
   }
   else{
      std::cout<<"from_string failed"<<std::endl;
   }
   if(from_string<float>(f,
                               std::string("123.456"),
                               std::dec))
   {
      std::cout<<f<<std::endl;
   }
   else{
      std::cout<<"from_string failed"<<std::endl;
   }
   return 0;
}


/* 输出:
255
123.456
*/


四, int char * float and CString Covernt


1。 int <->CString


1) int ->CString


int n = 1;


CString str;


str.Format("%d",n);


2) CString->int


CString str = "1";


int n = atoi(str.GetBuffer(0));


2. char* 与CString


1)char*->CString


char sz[128];


CString str;


str.Format("%s",sz);


2) CString -> char*


CString str;


//int nLength = str.GetLength();


char* sz = str.GetBuffer(0);


3. float<->CString


1)float->CString


float f = 0.0;


CString str;


str.Format("%f",f);


2) CString->float


CString str = "0.0";


float f = atof(str.GetBuffer(0));

PARTNER CONTENT

文章评论0条评论)

登录后参与讨论
EE直播间
更多
我要评论
0
10
关闭 站长推荐上一条 /3 下一条