流无处不在,只要是关于到文件的输入、输出、更新等,关于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. Java IO之File和IO

    本系列我们主要总结一下Java中的IO.NIO以及NIO2. java.io.File 学习Java IO,首先让我们来了解File类吧,它是文件和目录路径名的抽象表示形式.因此你千万别误会File类 ...

  2. ceph-deploy install时,远端节点在执行apt-get update命令时失败

    环境 OS:Ubuntu 16.04 背景 使用ceph-deploy部署Ceph集群,调用ceph-deploy install命令在远端节点安装ceph环境,执行apt-get update命令时 ...

  3. JavaScript中冒泡排序

    在我大学的时候,就已经接触到过很多的排序方式,只是那时候听得还很懵懂,大概知道这么个东西,也对冒泡排序有点印象,但真要我写,我是写不出来的.最近,在回顾js基础的时候,又接触到了冒泡排序.于是,就把冒 ...

  4. linux 私房菜 CH7 Linux 档案与目录管理

    路径 ``` . 此层目录 .. 上一级目录 前一个工作目录 ~ 当前用户的家的目录 ``` 变换目录 cd 显示目录 pwd [-P] -P 显示出确实的路径,而非使用链接 (link) 路径. 创 ...

  5. Python(五)编程小实例

    Python(五)编程小实例 抓取网页信息,并生成txt文件内容! Python抓取网页技能--Python抓取网页就是我们常看见的网络爬虫,我们今天所要用到的就是我们Python中自带的模块,用这些 ...

  6. AOP执行增强-Spring 源码系列(5)

    AOP增强实现-Spring 源码系列(5) 目录: Ioc容器beanDefinition-Spring 源码(1) Ioc容器依赖注入-Spring 源码(2) Ioc容器BeanPostProc ...

  7. Octave Tutorial(《Machine Learning》)之第五课《控制语句和方程及向量化》

    第五课 控制语句和方程 For,while,if statements and functions (1)For loop v=zeros(10,1) %initial vectors for i=1 ...

  8. iOS多线程——同步异步串行并行

    串行并行异步同步的概念很容易让人混淆,关于这几个概念我在第一篇GCD中有解释,但是还不够清晰,所以这里重写一篇博客专门对这几个概念进行区分: 先说一下队列和任务: (1)队列分为串行和并行,任务的执行 ...

  9. 对Vue.js $watch方法的理解

    博主最近对着vue.js的官方教程在自学vue.js,博主自幼愚钝,在教程中真的是好多点都不太理解,接下来要说的这个$watch方法就是其中一个不太理解的点了.咱们先来看一下对于$watch方法在vu ...

  10. cuda编程学习3——VectorSum

    这个程序是把两个向量相加 add<<<N,1>>>(dev_a,dev_b,dev_c);//<N,1>,第一个参数N代表block的数量,第二个参数1 ...