首页 > 其他 > 详细

C#: 将输出重定向

时间:2014-02-14 08:40:54      阅读:313      评论:0      收藏:0      [点我收藏+]

默认情况下,C# console Application 的标准输出就是那个控制台窗口,有时候可以重定到文件,以下是实现代码:

using System.IO;

using System.Text;

using System;

 

var defaultEncoding = Encoding.Default;

Console.WriteLine("开始时间:{0}",DateTime.Now.ToString());

//重定向输出到一个文件中

var stream = new FileStream("C:/log.txt",FileMode.Create);

Console.SetOut(new StreamWriter(stream));

Console.WriteLine("开始时间:{0}",DateTime.Now.ToString());

Console.WriteLine("结束时间:{0}",DateTime.Now.ToString());

//结束重定向

Console.Out.Close();

//将输出定向到控制台窗口

Console.SetOut(new StreamWriter(Console.OpenStandardOutput,defaultEncoding);

Console.WriteLine("结束时间:{0}",DateTime.Now.ToString());

Console.Out.Close();

 

Console.ReadKey();

需要注意的地方有两点:

1.在重新将输出定向到控制台窗口时,必须要指明Encoding的方式,这样才会用默认的DBCSCodePageCoding(我的电脑是简体中文系统)来处理中文,否则,”结束时间“这几个中文字会出现乱码

2.别忘了最后的Console.Out.Close(), 如果没有这个,最后一行文字就不显示到控制台窗口中(没搞明白为什么。。。)

C#: 将输出重定向

原文:http://www.cnblogs.com/sunshore/p/3548363.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!