程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> 關於C# >> 使用c#+(datagrid控件)編輯xml文件

使用c#+(datagrid控件)編輯xml文件

編輯:關於C#
 

這個源碼是我根據網上一個vb.net編輯xml文件的原理用c#重寫的。除重用xml文件外.
並未重用任何代碼!.

這小段代碼,可對xml文件的記錄進行刪除,修改,或增加新記錄。
利用了datagrid控件的sortcommand事件對xml裡的記錄進行排序。

email:ouyang76.263.net
------------------------------------------
<%@page language="c#" Trace="true"%>
<%@import namespace="System.Data"%>
<%@import namespace="System.IO"%>
<script language="c#" runat="server">
string xmlfile="books2.xml",xpath;
void page_load(Object obj,EventArgs e)
{
xpath=Server.MapPath(xmlfile);
if(!Page.IsPostBack)
{
Dataload("isbn");
}
}

void Dataload(string psort)
{
DataSet ds=new DataSet();
FileStream fs=new FileStream(xpath,FileMode.Open);
ds.ReadXml(fs);

if(ds.Tables.Count==0)
{
Response.Write("xml文件內無記錄!!!!");
fs.Close();
Response.End();
}
Trace.Warn("表記錄數",Convert.ToString(ds.Tables[0].Rows.Count));

DataRow dr=ds.Tables[0].NewRow();//新建一行
dr["ISBN"] = " Add ISBN";
ds.Tables[0].Rows.InsertAt(dr,0);//插入到第0行位置

Trace.Warn("表數目",Convert.ToString(ds.Tables.Count));//以紅字顯示調試信息

//grid1.DataSource=ds.Tables[0].DefaultView;
//grid1.DataBind();

DataView dv=new DataView(ds.Tables[0]);
Trace.Warn("字串長度:"+psort,Convert.ToString(psort.Length));//排序字符串的長度
if(psort.Length>0)
dv.Sort=psort;

grid1.DataSource=dv;
grid1.DataBind();
fs.Close();
}

void grid_sort(Object obj,DataGridSortCommandEventArgs e)
{
if(grid1.EditItemIndex==-1)
Dataload(e.SortExpression);
else
Response.Write("正在編輯暫不能排序!!");
}

void grid_edit(Object obj,DataGridCommandEventArgs e)
{
grid1.EditItemIndex=(int)e.Item.ItemIndex;
show_del("hide");
Dataload("");
}

void grid_cancel(Object obj,DataGridCommandEventArgs e)
{
grid1.EditItemIndex=-1;
show_del("show");
Dataload("");
}

void grid_update(Object obj,DataGridCommandEventArgs e)
{
int numcell=e.Item.Cells.Count;//單元格數目(e.Item是當前發生事件的表格行)
int currentrow=e.Item.DataSetIndex;
//int curr2=e.Item.ItemIndex;//與上句等價,可以不帶(int)
Trace.Warn("當前更新行號 = ",Convert.ToString(currentrow));
//Trace.Warn("2當前更新行號 = ",Convert.ToString(curr2));

DataSet ds=new DataSet();
ds.ReadXml(xpath);//將xml模式和數據讀取到dataSet;
DataRow dr;//表示DataTable中的一行信息.

if(currentrow==0)
dr=ds.Tables[0].NewRow();
else
dr=ds.Tables[0].Rows[e.Item.DataSetIndex - 1];

string[] str={"isbn", "author", "title", "category", "comments"};
int j=-1;
for(int i=2;i<numcell;i++)//跳過1和2column
{
j=j+1;
string ctext;
ctext=((TextBox)e.Item.Cells[i].Controls[0]).Text;

dr[str[j]] = ctext;
Trace.Warn(Convert.ToString(i)+str[j]+":每一行的文本",ctext);
}

if(currentrow==0)
{
Response.Write("加入新記錄!!");
ds.Tables[0].Rows.InsertAt(dr,0);
}

ds.WriteXml(xpath);//將表示dataset的xml寫入到xml文件中,包括數據和模式.
grid1.EditItemIndex = -1;//無此句仍在編輯界面
show_del("show");
Dataload("");
}

void show_del(string state)
{
string tmp=state;
switch(tmp)
{
case "show":
grid1.Columns[0].Visible = true;
break;
case "hide":
grid1.Columns[0].Visible = false;
break;
default:
grid1.Columns[0].Visible = true;
break;//也要帶break
}
}

void initialize(Object obj,DataGridItemEventArgs e)//注意參數與其它函數不同
{
//e.Item.Cells[0].Text="aaaaa";//
if(e.Item.ItemIndex==0)//如果是第一行
{
LinkButton a0=new LinkButton();
a0=(LinkButton)e.Item.Cells[0].Controls[0];

LinkButton a1=new LinkButton();
a1=(LinkButton)e.Item.Cells[1].Controls[0];//在grid內建一個linkbutton控件

if(a0.Text=="刪 除")
a0.Text="";
if(a1.Text=="編 輯")
a1.Text="[AddNew]";
}
}

void grid_del(Object obj,DataGridCommandEventArgs e)
{
Response.Write("XX");
Trace.Warn("正要刪除",Convert.ToString(e.Item.ItemIndex));//控件中的行數  

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved