我正在尝试学习用于数据存储的 LINQ 和 XML 文件,同时自学 C# 和 VS2010。我想读取一个 XML 文件,其中包含我在虚拟实验室中用于测试的一些 SQL 服务器的服务器信息列表。
我的 XML 文件如下所示:
<?xml version="1.0" encoding="utf-8" ?>
<ServerList>
<Server>
<Name>SQLSVR1</Name>
<Type>Windows Server 2008 R2</Type>
<Product>Microsoft SQL Server 2008</Product>
<Database>AspNetDB</Database>
<UID>Admin</UID>
<PWD>!Passw0rd</PWD>
</Server>
<Server>
<Name>SQLSVR2</Name>
<Type>Windows Server 2008 R2</Type>
<Product>Microsoft SQL Server 2008</Product>
<Database>AspNetDB</Database>
<UID>Admin</UID>
<PWD>!Passw0rd</PWD>
</Server>
</ServerList>
我有一个 Windows 窗体,它有一个组合框(“cbSQLServers”)。我想用 XML 文件的结果填充 Form_Load() 事件中的 ComboBox。
private void Form1_Load(object sender, EventArgs e)
{
string filePath = @"..\\..\\ServerList.xml";
if (File.Exists(filePath))
{
XDocument xDoc = XDocument.Load(filePath);
var data = from item in xDoc.Descendants("server")
select new
{
serverName = item.Element("Name").Value,
serverType = item.Element("Type").Value,
serverProduct = item.Element("Product").Value
};
foreach (var p in data)
cbSQLServers.Items.Add(p.ToString());
// I used the Console to test if it was doing anything.
// Console.WriteLine(p.ToString());
}
else
{
MessageBox.Show("The file " + filePath + " does not exist.");
}
}
我的最终目标是,当我运行程序并从 ComboBox 中选择一个项目时,它将在名为 LbLog 的表单的 ListBox 中显示该服务器的信息:
private void cbSQLServers_SelectedIndexChanged(object sender, EventArgs e)
{
/*
* Pseudo-code...not sure how to pass from Form1_Load() to _SelectedIndexChanged.
lbLog.Items.Add("Server Name: " + cbSQLServers.SelectedIndex);
lbLog.Items.Add("\t Type: " + cbSQLServers.SelectedIndex);
lbLog.Items.Add("\t Product: " + cbSQLServers.SelectedIndex);
lbLog.Items.Add("\t Database: " + cbSQLServers.SelectedIndex);
lbLog.Items.Add("\t UID: " + cbSQLServers.SelectedIndex);
lbLog.Items.Add("\t PWD: " + cbSQLServers.SelectedIndex);
*/
}
谁能帮我确定如何使用 LINQ 从 XML 文件中读取数据?
最佳答案
data 在你的代码中是一个匿名类型,调用 ToString() 可能不会给你你想要的。
如果以后要在cbSQLServers_SelectedIndexChanged 中使用cbSQLServers 的各个字段,您应该保存对象,而不是smash it into a string。 .
创建一个包含所需类型数据的类:
public class MyServer
{
public string Name { get; private set };
public string OS { get; private set };
public string Product { get; private set };
public MyServer(string name, string os, string product)
{
this.Name = name;
this.OS = os;
this.Product = product;
}
}
然后保存这个类型的实例:
cbSQLServers.DisplayMember = "Name";
foreach (var p in data)
cbSQLServers.Items.Add(new MyServer(p.servername, p.serverType, p.serverProduct));
然后在您的处理程序中,您可以使用所选组合框项目的各个字段:
MyServer selectedServer = cbSQLServers.SelectedItem as MyServer;
DoWhateverWith(selectedServer.OS);
关于c# - LINQ to XML 不工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9947498/
我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-
我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t
我花了三天的时间用头撞墙,试图弄清楚为什么简单的“rake”不能通过我的规范文件。如果您遇到这种情况:任何文件夹路径中都不要有空格!。严重地。事实上,从现在开始,您命名的任何内容都没有空格。这是我的控制台输出:(在/Users/*****/Desktop/LearningRuby/learn_ruby)$rake/Users/*******/Desktop/LearningRuby/learn_ruby/00_hello/hello_spec.rb:116:in`require':cannotloadsuchfile--hello(LoadError) 最佳
关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion在首页我有:汽车:VolvoSaabMercedesAudistatic_pages_spec.rb中的测试代码:it"shouldhavetherightselect"dovisithome_pathit{shouldhave_select('cars',:options=>['volvo','saab','mercedes','audi'])}end响应是rspec./spec/request
在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo
如何在ruby中调用C#dll? 最佳答案 我能想到几种可能性:为您的DLL编写(或找人编写)一个COM包装器,如果它还没有,则使用Ruby的WIN32OLE库来调用它;看看RubyCLR,其中一位作者是JohnLam,他继续在Microsoft从事IronRuby方面的工作。(估计不会再维护了,可能不支持.Net2.0以上的版本);正如其他地方已经提到的,看看使用IronRuby,如果这是您的技术选择。有一个主题是here.请注意,最后一篇文章实际上来自JohnLam(看起来像是2009年3月),他似乎很自在地断言RubyCL
我正在尝试在Ruby中复制Convert.ToBase64String()行为。这是我的C#代码:varsha1=newSHA1CryptoServiceProvider();varpasswordBytes=Encoding.UTF8.GetBytes("password");varpasswordHash=sha1.ComputeHash(passwordBytes);returnConvert.ToBase64String(passwordHash);//returns"W6ph5Mm5Pz8GgiULbPgzG37mj9g="当我在Ruby中尝试同样的事情时,我得到了相同sha
使用Ruby1.9.2运行IDE提示说需要gemruby-debug-base19x并提供安装它。但是,在尝试安装它时会显示消息Failedtoinstallgems.Followinggemswerenotinstalled:C:/ProgramFiles(x86)/JetBrains/RubyMine3.2.4/rb/gems/ruby-debug-base19x-0.11.30.pre2.gem:Errorinstallingruby-debug-base19x-0.11.30.pre2.gem:The'linecache19'nativegemrequiresinstall
C#实现简易绘图工具一.引言实验目的:通过制作窗体应用程序(C#画图软件),熟悉基本的窗体设计过程以及控件设计,事件处理等,熟悉使用C#的winform窗体进行绘图的基本步骤,对于面向对象编程有更加深刻的体会.Tutorial任务设计一个具有基本功能的画图软件**·包括简单的新建文件,保存,重新绘图等功能**·实现一些基本图形的绘制,包括铅笔和基本形状等,学习橡皮工具的创建**·设计一个合理舒适的UI界面**注明:你可能需要先了解一些关于winform窗体应用程序绘图的基本知识,以及关于GDI+类和结构的知识二.实验环境Windows系统下的visualstudio2017C#窗体应用程序三.
我知道全局变量$!包含最新的异常对象,但我对下面的语法感到困惑。谁能帮助我理解以下语法?rescue$! 最佳答案 此构造可防止异常停止您的程序并使堆栈跟踪冒泡。它还会将该异常作为值返回,这很有用。a=get_me_datarescue$!在此行之后,a将保存请求的数据或异常。然后您可以分析该异常并采取相应措施。defget_me_dataraise'Nodataforyou'enda=get_me_datarescue$!puts"Executioncarrieson"pa#>>Executioncarrieson#>>#更现实的