C#如何查找dataset某行数据
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C#如何查找dataset某行数据相关的知识,希望对你有一定的参考价值。
例如现在dataSet中有一dataTable其内容如下:
TABLE1
ID Name Age sex
1 jinn 20 男
2 kimi 19 女
N ......
现在我希望通过comboBox1去选择 Name 中的值来获得值行中的其他例数值.在 Label 显示出来.
下面是我在网上找的方法.可是不知道哪里错了.
private void button3_Click(object sender, EventArgs e)
DataSet dsts = dst; // dst 为现在有的 DataSet
string sName = comboBox2.Text;
DataView dv = new DataView(dsts.Tables["toTable"]);
//dv = dsts.Tables[0].DefaultView;
dv.RowFilter = "Name='" + sName + "'";
//dv.ToTable(true, "");
//string ob1 = dv.ToTable("Name").ToString(); //显示的结果也一样 -_-!!!
DataTable ob1 = dv.ToTable("Name");
DataTable ob2 = dv.ToTable("Age");
DataTable ob3 = dv.ToTable("Sex");
DataTable ob4 = dv.ToTable("ID");
dataGridView2.DataSource = dv; //这里可以在dataGV2中显示出来
//DataTable dt = dvw.ToTable(true, ",Age");
label4.Text = "Name:(" + ob1 + ") Age:(" + ob2 + ") Sex:(" + ob3 + ") ID:(" + ob4 + ")";
label5.Text = string.Format("Name:(0) Age:(1)Sex:(2) ID:(3)", ob1, ob2, ob3, ob4);
label4/ label5 输出结果: Name:(Name) Age:(Age) Sex:(Sex) ID:( ID)
希望的结果: 通过 comboBox2.Text = jinn
label4/ label5 输出结果: Name:( jinn) Age:(20) Sex:(男) ID:( 1)
或者说有什么方法获得某行的索引下标?
DataTable table = DataSet1.Tables["TABLE1"];
string expression;
expression = "Name ='"+sName+"'";
DataRow[] foundRows;
//使用选择方法来找到匹配的所有行。
foundRows = table.Select(expression);
//过滤行,找到所要的行。
for(int i = 0; i < foundRows.Length; i ++)
string str1 = Console.WriteLine(foundRows[i]["Name"]).ToString();
string str2 = Console.WriteLine(foundRows[i]["Age"]).ToString();
string str3 = Console.WriteLine(foundRows[i]["Sex"]).ToString();
string str4 = Console.WriteLine(foundRows[i]["ID"]).ToString();
label5.Text = string.Format("Name:(0) Age:(1)Sex:(2) ID:(3)", str1, str2, str3,str4);
本回答被提问者采纳
如何使用 C# 从 DataSet 创建包含多个工作表的 excel 文件
【中文标题】如何使用 C# 从 DataSet 创建包含多个工作表的 excel 文件【英文标题】:How to create excel file with multiple sheets from DataSet using C# 【发布时间】:2011-12-30 16:39:09 【问题描述】:。我已经成功创建了一个带有单张工作表的 excel 文件。但我无法为多张纸做到这一点。
问候 严厉的
【问题讨论】:
我想这取决于您如何看待创建 excel 文件。您是否正在寻找@为数据集中的每个表创建一个页面? 您可能更改了默认的 Excel 行为。见***.com/questions/8066189/… 您正在为已创建的单张工作表使用哪种技术或组件? 【参考方案1】:这是一个简单的 C# 类,它以编程方式创建 Excel 工作簿并向其中添加两个工作表,然后填充两个工作表。最后,它将 WorkBook 保存到应用程序根目录中的一个文件中,以便您检查结果...
public class Tyburn1
object missing = Type.Missing;
public Tyburn1()
Excel.Application oXL = new Excel.Application();
oXL.Visible = false;
Excel.Workbook oWB = oXL.Workbooks.Add(missing);
Excel.Worksheet oSheet = oWB.ActiveSheet as Excel.Worksheet;
oSheet.Name = "The first sheet";
oSheet.Cells[1, 1] = "Something";
Excel.Worksheet oSheet2 = oWB.Sheets.Add(missing, missing, 1, missing)
as Excel.Worksheet;
oSheet2.Name = "The second sheet";
oSheet2.Cells[1, 1] = "Something completely different";
string fileName = Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location)
+ "\\SoSample.xlsx";
oWB.SaveAs(fileName, Excel.XlFileFormat.xlOpenXMLWorkbook,
missing, missing, missing, missing,
Excel.XlSaveAsAccessMode.xlNoChange,
missing, missing, missing, missing, missing);
oWB.Close(missing, missing, missing);
oXL.UserControl = true;
oXL.Quit();
为此,您需要在项目中添加对 Microsoft.Office.Interop.Excel 的引用(您可能已经这样做了,因为您正在创建一张工作表)。
添加第二张表的语句是...
Excel.Worksheet oSheet2 = oWB.Sheets.Add(missing, missing, 1, missing)
as Excel.Worksheet;
“1”参数指定一个工作表,如果您想一次添加多个工作表,它可以更多。
最后说明:声明 oXL.Visible = false;告诉 Excel 以静默模式启动。
【讨论】:
我在 oXL.Quit() 上得到一个错误;每次。 Excel Undantagskod:xc0000005 Felförskjutning:0x000000000000f993。错误被放入机器的事件日志中。您还需要 C# 4 中缺少的参数吗?动态 oWB= excelApplication.Workbooks.Add(); 还不够吗?【参考方案2】:var groupedSheetList = UserData
.GroupBy (u => u.date)
.Select (grp => grp.ToList ())
.ToList ();
你可以试试这个
using (var package = new ExcelPackage ())
foreach (var item in groupedSheetList)
var workSheet = package.Workbook.Worksheets.Add (item[0].date);
【讨论】:
以上是关于C#如何查找dataset某行数据的主要内容,如果未能解决你的问题,请参考以下文章
聚合 C# 数据集时,如何将 DataSet 转换为 .Load() 的 DataTable 数组?