现在是XML盛行的时代,我想好多人早已用XML文档做为配置数据的载体了,而我是刚刚才掌握而已。现在写一点示例代码,希望对新朋友有所帮助。
这样操作的原理是使用FileStream和Dataset。将XML文件中读取到的字符串做为参数传递给Dataset,而形成一个Dataset数据集,我们再从数据集中读取数据。这对于习惯于操作数据库的朋友来说可能更为方便一些。但相信有很多朋友会选择直接读取XML文件中的XmlNodes,希望这些朋友看到时能给我回复一个更好的代码。谢谢。
以下就是全部的代码:
1
private void btnReadXML_Click(object sender, EventArgs e)
2
{
3
DataSet myDS = new DataSet();
4
string xmlData;
5
StringBuilder sb = new StringBuilder();
6
7
string fileName;
8
fileName = @"C:\Documents and Settings\guof\Desktop\Configure.xml";
9
10
try
11
{
12
FileStream fs = new FileStream(fileName, FileMode.Open);
13
StreamReader sr = new StreamReader(fs);
14
15
string strLine = "";
16
strLine = sr.ReadLine();
17
sb.Append(strLine);
18
while (!sr.EndOfStream)
19
{
20
strLine = sr.ReadLine();
21
sb.Append(strLine);
22
}
23
24
sr.Close();
25
fs.Close();
26
27
xmlData = sb.ToString();
28
29
StringReader xmlSR = new StringReader(xmlData);
30
31
myDS.ReadXml(xmlSR, XmlReadMode.InferSchema);
32
xmlSR.Close();
33
dgvXmlDS.DataSource = myDS.Tables[0];
34
}
35
catch (Exception ex)
36
{
37
MessageBox.Show(ex.Message);
38
}
39
}

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

以下是相关的XML文件内容:
1
<TSDS>
2
<ConfigureStrings>
3
<Server>sapf</Server>
4
<DBUser>sa</DBUser>
5
<DBPassword>sa</DBPassword>
6
</ConfigureStrings>
7
</TSDS>
由于仅是测试的代码,因此没有完整地遵循Try Catch结构,实际应用时还需要调整。
2

3

4

5

6

7

这段代码并不是高效地代码,希望朋友们帮我指正和回复更好的代码。