流无处不在,只要是关于到文件的输入、输出、更新等,关于IO流,项目中还是经常用到的,写log日志免不了要与其打交道,现在需要用到,就顺道好好回顾一下进行整理,首先是几个需要用到的类的说明,其实说简单点,就是对文件夹、文件、文件内容进行编辑。

1. 创建文件、文件夹

        public void OperationFile()
{
//创建文件
if (!File.Exists("Log.txt"))
{
File.Create("Log.txt"); } //创建文件夹
if (!Directory.Exists("Log"))
{
Directory.CreateDirectory("Log");
}
}

2. 读写数据到文件中

FileStream 原始,比较复杂,处理的数据多

读取文件数据

        public void ReadFileStream()
{
//打开数据
//FileStream fs = File.OpenRead("201704191450.txt");
//FileInfo fileinfo = new FileInfo("201704191450.txt");
//FileStream fs = fileinfo.OpenRead(); //读取数据
byte[] bytedata = new byte[];
char[] chardata = new char[];
FileStream ffs = new FileStream("TestRead.txt",FileMode.Open);
//执行文件指针位置
ffs.Seek(,SeekOrigin.Begin);
//读取数据,其起始位置为seek指定的指针位置末
ffs.Read(bytedata,,);
//设置转码格式
Decoder d = Encoding.UTF8.GetDecoder();
d.GetChars(bytedata,,bytedata.Length,chardata,);
Console.WriteLine(chardata);
Console.ReadKey(); }

写入文件数据

        public void WriteFileStream()
{
//写入数据
byte[] byteData = new byte[];
char[] charData = new char[];
FileStream fis = new FileStream("TestWrite.txt", FileMode.Create);
charData = ("This is a jokey").ToArray();
byteData = new byte[charData.Length];
Encoder e = Encoding.UTF8.GetEncoder();
e.GetBytes(charData, , charData.Length, byteData, , true);
fis.Seek(, SeekOrigin.Begin);
fis.Write(byteData, , byteData.Length);
}

由此可见,操作字符数据比较麻烦。而StreamWritrer、StreamReader不需要设置指针位置,读写文件时,比较灵活

StreamReader读取文件数据

        /// <summary>
/// StreamReader读取日志
/// </summary>
public void ReadLog()
{
StreamReader sr = new StreamReader("201704191451.txt", true);
string line = sr.ReadLine();
while (line!=null)
{
Console.WriteLine(line);
line = sr.ReadLine();
} sr.Close();
}

StreamWriter写入文件数据

        /// <summary>
/// StreamWrite写入日志
/// </summary>
/// <param name="ex"></param>
public void WriteExLog(string ex)
{
StreamWriter sw = new StreamWriter(DateTime.Now.ToString("yyyyMMddHHmm")+".txt",true);
sw.WriteLine(DateTime.Now.ToString("G")+" "+ex);
sw.Close(); }

两者一进行对比,可见StreamWriter、StreamReader确实比FileStream方便很多

关于流文件的使用,上面仅仅是单一的操作,实际项目中,多为混合模式,各种判断柔和在一起,这里也不多说什么,先写一个相对来书综合点的方法

       public void OperationStream()
{
//当前Debug下+创建文件夹
string straddrsfile = AppDomain.CurrentDomain.BaseDirectory + Path.DirectorySeparatorChar.ToString() + "Test1";
//当前路径+文件名
string straddrspath = straddrsfile + Path.DirectorySeparatorChar.ToString() + "Test1" + DateTime.Now.ToString("yyyyMMddHHmmss") + ".xml";
straddrspath = straddrspath.Replace("\\", "/");
if (!File.Exists(straddrsfile))
{
//创建文件夹
Directory.CreateDirectory(straddrsfile);
//创建文件
StreamWriter sw = new StreamWriter(straddrspath,true);
//写入数据
sw.WriteLine(DateTime.Now.ToString("G") + "This is a jokey");
sw.Close();
//读取数据
StreamReader sr = new StreamReader(straddrspath,true);
string line = sr.ReadLine();
//输出数据
while (line != null)
{
Console.WriteLine(line);
line = sr.ReadLine();
}
sr.Close();
Console.ReadKey();
}
}

对于这些流关联的类,其重载的方法有很多,向那些参数的说明,指尖敲击下键盘,点下联想看看说明,就出来,总之,深入的研究清一个问题需要大量的时间,结果还未可知,当前项目既然需要这个日志,就稍稍巩固下。

------分割线---------------

实战:现在接手的项目中需要异常日志,初步思路如下:

        //記錄異常日誌  Log file txt
public void WriteTxtLog(Exception ex,string sysCode,string functId)
{
//文件夾名稱
string logFolder = ConfigurationManager.AppSettings["LogFolder"];
//文件名
string logFolderName = ConfigurationManager.AppSettings["LogFolderName"];
//文件夾路徑
string logFolderPath = ConfigurationManager.AppSettings["LogFolderPath"];
//文件路徑
string path = logFolderPath + "\\" + logFolder + "\\" + DateTime.Now.ToString("yyyyMMdd") + logFolderName;
//创建文件夹
if (!Directory.Exists(logFolderPath+"\\"+ logFolder))
{
Directory.CreateDirectory(logFolderPath + "\\" + logFolder);
}
//不存存在txt,則創建,存在則追加
var sw = !File.Exists(path) == true ? new StreamWriter(path, true) : File.AppendText(path);
//写入数据
sw.WriteLine("..................");
sw.WriteLine("異常日誌,開始時間:" + DateTime.Now.ToString("yyyyMMdd HH:mm:ss"));
sw.WriteLine("系統名:" + sysCode + " 功能代號:" + functId + " 異常錯誤信息:" + ex.ToString());
sw.WriteLine("異常日誌,完成時間:" + DateTime.Now.ToString("yyyyMMdd HH:mm:ss"));
sw.WriteLine("..................");
sw.Close();
}

市人皆大笑,举手揶揄之

IO流中的Stream相关对象的更多相关文章

  1. 第54节:Java当中的IO流(中)

    Java当中的IO流(中) 删除目录 // 简书作者:达叔小生 import java.io.File; public class Demo{ public static void main(Stri ...

  2. Java当中的IO流(中)

    Java当中的IO流(中) 删除目录 import java.io.File; public class Demo{ public static void main(String[] args){ / ...

  3. 规范之“用流中的Stream.Of(arr1,arr2)将两个集合合并”

    案例:用流中的Stream.Of(arr1,arr2)将两个集合合并 /** * 功能描述: * 两个对象集合添加到一起 * 在用flatMap扁平化改为Stream<User> * 这样 ...

  4. 揭开Java IO流中的flush()的神秘面纱

    大家在使用Java IO流中OutputStream.PrintWriter --时,会经常用到它的flush()方法. 与在网络硬件中缓存一样,流还可以在软件中得到缓存,即直接在Java代码中缓存. ...

  5. io流中的装饰模式对理解io流的重要性

    为了说明 io流中的装饰者模式对理解io流的重要性,我想先简要介绍以下io的装饰模式. 装饰(decorator)你也可以翻译成修饰.比如:一个会精通化学数学的物理学家.在这个"物理学家&q ...

  6. Java中IO流中所涉及到的各类方法介绍

    IO流之字节流 (1)IO用于在设备间进行数据传输的操作 (2)分类: A:流向 输入流 读取数据 输出流 写出数据 B:数据类型 字节流 字节输入流 字节输出流 字符流 字符输入流 字符输出流 注意 ...

  7. IO流中的字符输入输出流及try...catch处理流处理中的异常

    使用字节流读取中文的问题 import java.io.FileInputStream; import java.io.IOException; /* 使用字节流读取中文文件 1个中文 GBK:占用两 ...

  8. 关于Java中面向对象章节、IO 流中的重点基础知识。

    一.面向对象的三大特征,以及作用. 答:面向对象的三大特征即,封装性.继承性.多态性. 其分别的作用为 : 封装作用:将数据封装起来,提高数据的安全性, 继承作用:提高代码的复用性,减少冗余代码. 多 ...

  9. Java中IO流中的装饰设计模式(BufferReader的原理)

    本文粗略的介绍下JavaIO的整体框架,重在解释BufferReader/BufferWriter的演变过程和原理(对应的设计模式) 一.JavaIO的简介 流按操作数据分为两种:字节流与字符流. 流 ...

随机推荐

  1. if(){}else 语句的正确写法以及它的嵌套使用

    if(一个返回bool值的条件表达式) { 程序块 } else{} 它的执行过程我们可以通过一个程序来了解 static void Main(string[] args) { ) // 条件1 { ...

  2. Modbus软件开发实战指南 之 开发自己的Modbus Poll工具 - 1

    在开发Modbus程序的过程中,也可以发现经常需要使用诸如Modbus Poll和Modbus Slave等辅助调试工具, 用于验证MODBUS通讯消息是否正确.但是,Modbus Poll和Modb ...

  3. 出现http://cwiki.apache.org/confluence/display/MAVEN/MojoFailureException异常

    解决方案 1.在eclipse的菜单中,进入Window > Preferences > Java > Installed JREs > Execution Environme ...

  4. 基于 Koa平台Node.js开发的KoaHub.js的控制器,模型,帮助方法自动加载

    koahub-loader koahub-loader是基于 Koa平台Node.js开发的KoaHub.js的koahub-loader控制器,模型,帮助方法自动加载 koahub loader I ...

  5. 算法模板——Dinic网络最大流 1

    实现功能:同sap网络最大流 今天第一次学Dinic,感觉最大的特点就是——相当的白话,相当的容易懂,而且丝毫不影响复杂度,顶多也就是代码长个几行 主要原理就是每次用spfa以O(n)的时间复杂度预处 ...

  6. 关于mui选择器的使用

    使用mui引入选择器的picker.js.poppicker.js.及他们的css文件之后引入代码与点击确定之后的状态: document.querySelector('#osex').addEven ...

  7. Git远程仓库(二)

    昨天讲了Git安装使用和基本的命令,今天我说一下如何通过Git将本地管理的仓库添加到远程库 首先我们需要在www.github.com(如果打不开网页,请注意科学上网)上注册一个免费的账号,邮箱验证完 ...

  8. pcntl_fork 导致 MySQL server has gone away 解决方案

    pcntl_fork 前连数据库,就会报 MySQL server has gone away 错误.原因是子进程会继承主进程的数据库连接,当mysql返回数据时,这些子进程都可以通过这个连接读到数据 ...

  9. MSDN官方数据库开发群

    QQ群1:43563009 创建人:中国风(Roy_88) 创建时间:2007-07-21 当前人数:326人 QQ群2:27156079 创建人: fcuandy 创建时间:2008-03-20 当 ...

  10. MySQL1236错误的恢复

    从库出现问题 mysql> show slave status\G; *************************** . row *************************** ...