I have this function:
void Log::Write(string logline){
//2011-10-12 13:07:40 correct format
time_t rawtime;
开发者_开发问答struct tm * timeinfo;
time ( &rawtime );
timeinfo = localtime ( &rawtime );
m_stream.write( asctime (timeinfo), 24 );
m_stream << " - " << logline << std::endl;
}
The output is like this:
Thu Oct 13 12:35:30 2011
but I wanna see the output like the comment section:
2011-10-12 13:07:40
How is it possible?
It's very possible. Look at the manpage for strftime()
. In this case, you'd want:
void Log::Write(string line)
{
time_t rawtime;
struct tm * timeinfo;
char buffer [80];
time ( &rawtime );
timeinfo = localtime ( &rawtime );
strftime (buffer,80,"%Y-%m-%d %H:%M:%S",timeinfo);
m_stream << buffer << " - " << line << endl;
}
Boost offers a library for that.
You can use the strftime()
function to format times in all ways you want. In your case the format string "%Y-%m-%d %H:%M:%S"
should produce the desired result.
You can use strftime() to convert a struct tm into a string with somewhat flexible formatting.
精彩评论