Csharp:The .dat File using BinaryReader and BinaryWriter Convert to DataTable

 /// <summary>
        /// 添加
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void button1_Click(object sender, EventArgs e)
        {
            BinaryWriter binWriter = new BinaryWriter(File.OpenWrite(datfile), Encoding.Unicode);//StreamWriter           
            binWriter.Seek(0, SeekOrigin.End);
            num =int.Parse(this.textBox1.Text.Trim());
            strsex = this.textBox2.Text.Trim();
            strname = this.textBox3.Text.Trim();
            creatdate =this.dateTimePicker1.Value;
            binWriter.Write(num);
            binWriter.Write(strsex);
            binWriter.Write(strname);
            binWriter.Write(creatdate.ToShortDateString() + Environment.NewLine);
            binWriter.Flush();
            binWriter.Close();


        }



        /// <summary>
        /// 顯示全部
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void button2_Click(object sender, EventArgs e)
        {

            //創建文件
            //Write out to binary file
            //if (!File.Exists(datfile))
            //{
            //    FileStream myFile = File.Create(datfile);
            //    myFile.Close();
            //}
            //strsex = "男";
            //num = 124;
            //creatdate = DateTime.Now;
            //strname = "塗聚文geovindu";
            //BinaryWriter binWriter = new BinaryWriter(File.OpenWrite(datfile), Encoding.Unicode);//StreamWriter 
            //binWriter.Write(num);
            //binWriter.Write(strsex);
            //binWriter.Write(strname);
            //binWriter.Write(creatdate.ToShortDateString() + Environment.NewLine);
            ////binWriter.Seek(1, SeekOrigin.Begin);
            //strsex = "男";
            //num = 125;
            //creatdate = DateTime.Now;
            //strname = "劉志軍";
            ////BinaryWriter binWriter = new BinaryWriter(File.OpenWrite(datfile));
            //binWriter.Write(num);
            //binWriter.Write(strsex);
            //binWriter.Write(strname);
            //binWriter.Write(creatdate.ToShortDateString() + Environment.NewLine);
            ////binWriter.Seek(2, SeekOrigin.Current);
            //strsex = "女";
            //num = 126;
            //creatdate = DateTime.Now;
            //strname = "孩子";
            ////BinaryWriter binWriter = new BinaryWriter(File.OpenWrite(datfile));
            //binWriter.Write(num);
            //binWriter.Write(strsex);
            //binWriter.Write(strname);
            //binWriter.Write(creatdate.ToShortDateString() + Environment.NewLine);
            ////binWriter.Seek(3, SeekOrigin.Current);
            //binWriter.Flush();
            //binWriter.Close();

            //Read from binary file
            //最一條
            //byte[] bs;
            //using (FileStream fs = new FileStream(datfile, FileMode.Open, FileAccess.Read))
            //{
            //    using (BinaryReader br = new BinaryReader(fs))
            //    {
            //        bs = br.ReadBytes((int)fs.Length);
            //    }
            //}
            //foreach (byte detail in bs)
            //{
            //    Console.WriteLine(detail);
            //}
            dt = null;
            dt = new DataTable();
            dt.Columns.Add("ID", typeof(int));
            dt.Columns.Add("Sex", typeof(string));
            dt.Columns.Add("ReName", typeof(string));
            dt.Columns.Add("CreateTime", typeof(DateTime));

            using (BinaryReader binaryReader = new BinaryReader(File.Open(datfile, FileMode.Open), Encoding.Unicode))
            {
                
                //binaryReader.BaseStream.Seek(0, SeekOrigin.Begin);
                //1
                //while (true)
                //{
                //    num  = binaryReader.ReadInt32();
                //    strsex = binaryReader.ReadString();
                //    strname = binaryReader.ReadString();
                //    creatdate = DateTime.Parse(binaryReader.ReadString());
                //    //data.Add(k, v);

                //    if (binaryReader.BaseStream.Position == binaryReader.BaseStream.Length)
                //        break;
                //}
                //
                //2
                while (binaryReader.PeekChar() != -1)
                {
                    try
                    {
                        num = binaryReader.ReadInt32();
                        strsex = binaryReader.ReadString();
                        strname = binaryReader.ReadString();
                        creatdate = DateTime.Parse(binaryReader.ReadString());
                        dt.Rows.Add(num, strsex, strname, creatdate);
                    }
                    catch (Exception ex)
                    {
                        ex.Message.ToString();
                        break;
                    }


                }
                binaryReader.Close();
            }

            //BinaryReader binReader = new BinaryReader(File.OpenRead(datfile), Encoding.Unicode);

            //num = binReader.ReadInt32();
            //strsex = binReader.ReadString();
            //strname = binReader.ReadString();
            //creatdate = DateTime.Parse(binReader.ReadString());

            this.textBox1.Text = num.ToString();
            this.textBox2.Text = strsex;
            this.textBox3.Text = strname;
            this.dateTimePicker1.Value = creatdate;
            //binReader.PeekChar();

            //num = binReader.ReadInt32();
            //this.textBox4.Text = num.ToString();
            //binReader.Close();

            this.dataGridView1.DataSource = dt;

        }
        /// <summary>
        /// 
        /// </summary>
        /// <param name="FilePath"></param>
        /// <param name="buff"></param>
        public static void WriteBuffer(string FilePath, byte[] buff)
        {
            StreamWriter Writer = File.AppendText(FilePath);
            foreach (byte i in buff)
                Writer.BaseStream.WriteByte(i);
            Writer.Close();
        }
        /// <summary>
        /// 查找
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void button3_Click(object sender, EventArgs e)
        {
            string s = this.textBox4.Text.Trim();
            using (BinaryReader binaryReader = new BinaryReader(File.Open(datfile, FileMode.Open), Encoding.Unicode))
            {
                //binaryReader.BaseStream.Seek(0, SeekOrigin.Begin);
                //1
                //while (true)
                //{
                //    num  = binaryReader.ReadInt32();
                //    strsex = binaryReader.ReadString();
                //    strname = binaryReader.ReadString();
                //    creatdate = DateTime.Parse(binaryReader.ReadString());
                //    //data.Add(k, v);

                //    if (binaryReader.BaseStream.Position == binaryReader.BaseStream.Length)
                //        break;
                //}
                //
                //2
                while (binaryReader.PeekChar() != -1)
                {
                    try
                    {
                        num = binaryReader.ReadInt32();
                        strsex = binaryReader.ReadString();
                        strname = binaryReader.ReadString();
                        creatdate = DateTime.Parse(binaryReader.ReadString());
                        if (strname.Contains(s))
                        {
                            this.label2.Text=binaryReader.BaseStream.Position.ToString();
                            this.label3.Text =(binaryReader.BaseStream.Length-binaryReader.BaseStream.Seek(0, SeekOrigin.Current)).ToString();
                            setCurrent = binaryReader.BaseStream.Seek(0, SeekOrigin.Current);
                            //binaryReader.BaseStream.Seek((binaryReader.BaseStream.Position / 50) * 50, 0);                              
                            this.textBox1.Text = num.ToString();
                            this.textBox2.Text = strsex;
                            this.textBox3.Text = strname;
                            this.dateTimePicker1.Value = creatdate;
                        }

                    }
                    catch (Exception ex)
                    {
                        ex.Message.ToString();
                        break;
                    }


                }



                binaryReader.Close();
            }
        }
        /// <summary>
        /// 修改,創建
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void button4_Click(object sender, EventArgs e)
        {
            #region 創建 塗聚文 20130329

            //if (File.Exists(datfile))
            //{
            //    File.Delete(datfile);
            //}

            //dt = null;
            //dt = new DataTable();
            //dt.Columns.Add("ID", typeof(int));
            //dt.Columns.Add("Sex", typeof(string));
            //dt.Columns.Add("ReName", typeof(string));
            //dt.Columns.Add("CreateTime", typeof(DateTime));
            //dt.Rows.Add(1, "男", "塗聚文", "2013-03-1");
            //dt.Rows.Add(2, "女", "王熙鳳", "2013-03-11");
            //dt.Rows.Add(3, "女", "劉麗", "2013-03-21");
            //dt.Rows.Add(4, "男", "劉海粟", "2013-03-3");
            //dt.Rows.Add(5, "男", "高春輝", "2013-03-5");
            //BinaryWriter binWriter = new BinaryWriter(File.OpenWrite(datfile), Encoding.Unicode);//StreamWriter  
            ////binWriter.BaseStream.Seek(0, SeekOrigin.Current);
            //////binWriter.Seek((int)setCurrent, SeekOrigin.Current);//定位有問題
            //foreach (DataRow dr in dt.Rows)
            //{
            //    num=(int)dr["ID"];
            //    strsex =(string) dr["Sex"];
            //    strname = (string)dr["ReName"];
            //    creatdate =(DateTime)dr["CreateTime"];
            //    binWriter.Write(num);
            //    binWriter.Write(strsex);
            //    binWriter.Write(strname);
            //    binWriter.Write(creatdate.ToShortDateString() + Environment.NewLine); //+ Environment.NewLine //加一行,成了現在的行
            //}

            //binWriter.Flush();
            //binWriter.Close();
            #endregion 



            //num = int.Parse(this.textBox1.Text.Trim());
            //strsex = this.textBox2.Text.Trim();
            //strname = this.textBox3.Text.Trim();
            //creatdate = this.dateTimePicker1.Value;
            //binWriter.Write(num);
            //binWriter.Write(strsex);
            //binWriter.Write(strname);
            //binWriter.Write(creatdate.ToShortDateString()); //+ Environment.NewLine //加一行,成了現在的行

            //binWriter.Flush();
            //binWriter.Close();

            //using (BinaryReader binaryReader = new BinaryReader(File.Open(datfile, FileMode.Open), Encoding.Unicode))
            //{
            //    while (binaryReader.PeekChar() != -1)
            //    {
            //        //binaryReader.BaseStream.Seek(setCurrent, SeekOrigin.Begin);
            //        num = binaryReader.ReadInt32();
            //        strsex = binaryReader.ReadString();
            //        strname = binaryReader.ReadString();
            //        creatdate = DateTime.Parse(binaryReader.ReadString());
            //        this.textBox1.Text = num.ToString();
            //        this.textBox2.Text = strsex;
            //        this.textBox3.Text = strname;
            //        this.dateTimePicker1.Value = creatdate;
            //    }
            //}
            

            #region 修改

            BinaryWriter binWriter = new BinaryWriter(File.OpenWrite(datfile), Encoding.Unicode);//StreamWriter 
            binWriter.BaseStream.Position = 0;
            num = 8;// int.Parse(this.textBox1.Text.Trim());
            strsex = "女";// this.textBox2.Text.Trim();
            //strname = this.textBox3.Text.Trim();
            //creatdate = this.dateTimePicker1.Value;
            binWriter.Write(num);
            binWriter.BaseStream.Position = 4;
            binWriter.Write(strsex);
            //binWriter.Write(strname);
            //binWriter.Write(creatdate.ToShortDateString()); //+ Environment.NewLine //加一行,成了現在的行
            binWriter.Flush();
            binWriter.Close();

            #endregion 

            #region 查找數據位置
            cudt = null;
            cudt = new DataTable();
            cudt.Columns.Add("ID", typeof(int));
            cudt.Columns.Add("Position", typeof(int));
            cudt.Columns.Add("Legnth", typeof(int));
            cudt.Columns.Add("Sart", typeof(int));
            cudt.Columns.Add("End", typeof(int));
            cudt.Columns.Add("Name", typeof(string));
            cudt.Columns.Add("Value", typeof(string));

                int pos = 0;
                int row = 0;
                int p = 0;
                int br = 0;
                string s = "";
                int starpos = 0;
                int endpos = 0;
            // 1.
            using (BinaryReader b = new BinaryReader(File.Open(datfile, FileMode.Open, FileAccess.Read),Encoding.Unicode))
            {
                // 2.
                // Position and length variables.

                // 2A.
                // Use BaseStream.
                int length = (int)b.BaseStream.Length;
                int k = 0;
                while (b.PeekChar() != -1)//pos < length
                {

                    try
                    {
                        starpos = (int)b.BaseStream.Position;
                        //
                        num = b.ReadInt32();  
                        p = (int)b.BaseStream.Position;
                        endpos = (int)b.BaseStream.Position;
                        pos = p;
                       // b.BaseStream.Seek(pos, SeekOrigin.Current);
                        br = (int)b.BaseStream.Length-p;
                        s = b.GetType().ToString();
                       cudt.Rows.Add(row, pos, br, starpos, endpos, s,num.ToString());//添加第一記錄  
                        //第二條記錄
                       starpos = (int)b.BaseStream.Position;
                        strsex = b.ReadString();
                        p = (int)b.BaseStream.Position;
                        endpos = p; 
                        pos = p;             
                        br = (int)b.BaseStream.Length-p;
                        s = b.GetType().ToString();  
                        cudt.Rows.Add(row, pos, br, starpos, endpos, s,strsex);//添加第二條記錄  
                        //第三第記錄
                        starpos=(int)b.BaseStream.Position;
                        strname = b.ReadString();
                        p = (int)b.BaseStream.Position;
                        endpos = p;                                              
                        pos = p;                        
                       // b.BaseStream.Seek(pos, SeekOrigin.Current);
                        br = (int)b.BaseStream.Length - p;
                        s = b.GetType().ToString();
                        cudt.Rows.Add(row, p, br, starpos, endpos, s,strname);//添加第三條記錄 

                        //第四條記錄
                        starpos = (int)b.BaseStream.Position;  
                        creatdate = DateTime.Parse(b.ReadString());
                        p = (int)b.BaseStream.Position;
                        endpos = p;  
                        pos = p;
                        br = (int)b.BaseStream.Length - p;  
                        s = b.GetType().ToString();
                        cudt.Rows.Add(row, p, br, starpos, endpos, s, creatdate);//第四記錄                                

                        k++;
                    }


                    catch (Exception ex)
                    {
                        ex.Message.ToString();
                        break;

                    }
                   

                    // 4.
                    // Advance our position variable.
                    pos += sizeof(int);
                    row++;
                }

                //b.BaseStream.Seek(7, SeekOrigin.Current);
                //string f=b.ReadString();
                //MessageBox.Show(f);
                //指定位顯示
                b.BaseStream.Position = 0;
                MessageBox.Show(b.ReadInt32().ToString());
                b.BaseStream.Position = 4;
                MessageBox.Show(b.ReadString());
                b.BaseStream.Position = 7;
                MessageBox.Show(b.ReadString());
                b.Close();

            }
           this.dataGridView2.DataSource = cudt;
            #endregion 



       }


        /// <summary>
        /// 
        /// </summary>
        /// <param name="sectorid"></param>
        /// <returns></returns>
        //public string getclientid(string sectorid)
        //{
        //    try
        //    {
        //        DataSet dsobj = new DataSet();
        //        bllobj = new ConverterClass();
        //        string retclientval = "0";

        //        dsobj = bllobj.BinaryDeSerialize(strDataPath + "\\" + "BinaryClientlocation.dat");
        //        DataRow[] dr = dsobj.Tables[0].Select("client_location_id in(" + locationid + ")");
        //        if (dr.Length > 0)
        //        {
        //            foreach (DataRow drow in dr)
        //            {
        //                retclientval = retclientval + "," + drow["client_id"].ToString();
        //            }
        //        }
        //        return retclientval;
        //    }
        //    catch (Exception ex)
        //    {
        //        ex.Message.ToString();
        //    }
        //}
    }

你可能感兴趣的:(File,Datatable,.dat)