- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我想读取 MSI 文件(Windows 安装程序包)。我编写了一个如下所示的函数,它采用两个输入参数:msifileName 和表名称并返回一个数据表,它是 MSI 表之一。
public DataTable ReadMsiPropertyTable(string msiFile, string tableName)
{
Type installerType = Type.GetTypeFromProgID("WindowsInstaller.Installer");
WindowsInstaller.Installer installer = (WindowsInstaller.Installer)Activator.CreateInstance(installerType);
Database database = installer.OpenDatabase(msiFile, 0);
string sqlQuery = String.Format("SELECT * FROM {0}",tableName);
View view = database.OpenView(sqlQuery);
view.Execute(null);
Record record = view.Fetch();
DataTable msiPropertyTable = new DataTable();
msiPropertyTable.Columns.Add("Column1", typeof(string));
msiPropertyTable.Columns.Add("Column2", typeof(string));
msiPropertyTable.Columns.Add("Column3", typeof(string));
msiPropertyTable.Columns.Add("Column4", typeof(string));
while (record != null)
{
int fieldCount;
fieldCount = record.FieldCount;
msiPropertyTable.Rows.Add(record.get_StringData(0), record.get_StringData(1), record.get_StringData(2), record.get_StringData(3));
record = view.Fetch();
}
return msiPropertyTable;
}
使用上面的代码片段,记录的行数和列数是未知的。所以我只静态返回四列。我想返回记录中的 MSI 表的所有行和列。
所以请告诉我如何将 View 或记录的输出转换为数据集,然后绑定(bind)到数据表。或者有没有其他方法可以返回所有的行和列。提前致谢。
最佳答案
这是使用互操作类型而不是 DTF 类型的类似逻辑。如您所见,还有很多工作要做。它也更加脆弱,因为涉及 COM 而不是 P/Invoke。此外,如果您可以消除创建 ADO.NET DataTable 的要求,DTF 将支持 LINQ 查询和数据绑定(bind)。换句话说,我写这篇文章只是为了好玩。我永远不会在实际代码中使用此方法。
public static DataTable ReadMsiPropertyTable(string msiFile, string tableName)
{
DataTable dataTable = new DataTable(tableName);
Type installerType = Type.GetTypeFromProgID("WindowsInstaller.Installer");
Installer installer = (WindowsInstaller.Installer)Activator.CreateInstance(installerType);
Database database = installer.OpenDatabase(msiFile, MsiOpenDatabaseMode.msiOpenDatabaseModeReadOnly);
string sqlQuery = String.Format("SELECT * FROM {0}", tableName);
View view = database.OpenView(sqlQuery);
view.Execute(null);
Record names = view.ColumnInfo[MsiColumnInfo.msiColumnInfoNames];
Record types = view.ColumnInfo[MsiColumnInfo.msiColumnInfoTypes];
Record row = view.Fetch();
for (int index = 1; index < names.FieldCount+1; index++)
{
string columnName = names.get_StringData(index);
string columnSpec = types.get_StringData(index);
switch (columnSpec.Substring(0, 1).ToLower())
{
case "s":
dataTable.Columns.Add(columnName, typeof(String));
break;
case "l":
dataTable.Columns.Add(columnName, typeof(String));
break;
case "i":
dataTable.Columns.Add(columnName, typeof(Int32));
break;
case "v":
dataTable.Columns.Add(columnName, typeof (Stream));
break;
}
}
while (row != null)
{
DataRow dataRow = dataTable.NewRow();
for (int index = 0; index < dataTable.Columns.Count; index++)
{
if(dataTable.Columns[index].DataType == typeof(String))
{
dataRow[index] = row.StringData[index + 1];
}
else if(dataTable.Columns[index].DataType == typeof(Int32))
{
dataRow[index] = row.IntegerData[index + 1];
}
else if(dataTable.Columns[index].DataType == typeof(Stream))
{
// Insanity has it's limits. Not implemented.
}
}
dataTable.Rows.Add(dataRow);
row = view.Fetch();
}
return dataTable;
}
关于c# - 如何在 C# 中将 WindowsInstaller.Record 转换为 System.Data.Dataset 或数据表(在读取 MSI 文件时),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14020285/
recorder = new MediaRecorder(); recorder.setAudioSource(MediaRecorder.AudioSource.VOICE_CALL
在我的表中,我有四列。 r_id id(用户 ID) v_id(公司 ID) 率 我所做的就是从用户那里对公司(v_id)进行评分。 假设,如果用户一对第一家公司(v_id)进行评分,那么当同一用户对
我的表中有 10 条记录,当我删除记录 5 并创建新记录时,新记录将取代已删除的记录,如下所示: 在删除之前记录其ID: 1个2个3个4个5个6个78个910 删除记录 5 并插入新记录后,id 为
我有两个 belongsToMany 模型: const apptsModel = db.define('Appts', { id: {type: Sequelize.INTEGER, pri
有没有办法在 iOS Playground 上使用录音机?运行时,它会询问我是否允许使用我的麦克风,并且录音机实例似乎可以正常工作,但是,我无法使用 record() 函数。我当前的环境是 iOS 1
我有 2 个表,状态表与配置文件表相连。 Profile 表存储唯一的 tagId,status 表存储多个重复的 tagid 条目。我想按tagid的最后一条记录和第一条记录分组显示。 表:简介注意
我是 的新手 typescript 我需要遍历 Record键入对值进行一些更新并返回 Record . 这是定义类型的方式: type Parent = Readonly>; type Childr
我发现在开发 extjs 应用程序(拉力赛应用程序)时,有时我需要从记录中获取的数据在 record.raw 中而不是在 record.data 中。两者有什么区别,为什么会这样? 编辑 - 添加示例
我需要交叉引用 2 个表。 在 tb1 中是 booking_ref,投资者 在 tb2 中是 booking_ref、investor、cost 麻烦的是如果没有成本,表2中没有记录 所以我有以下查
鉴于:我在 Kafka 中有两个主题,假设主题 A 和主题 B。Kafka Stream 从主题 A 读取记录,处理它并生成与消费记录相对应的多条记录(假设记录 A 和记录 B)。现在,问题是如何使用
我有一个包含 6 个元素的排序数组列表。前 5 个元素有一些值,第 6 个元素为空。 我想循环遍历这个ArrayList,并将第一个记录的前5个元素与下一个记录中的相同元素进行比较。如果任一元素不同,
我有一个包含 3 列的表:ID、Name、ParentID。 如何删除特定记录及其所有子记录(n 层深)? 使用 Entity Framework 3.5。 最佳答案 表是自引用的是应用程序逻辑,它没
获取记录时如何获取最新的记录? 例如: 第一次迭代我用对象名称 Country 保存“Singapore”, 第二次迭代我用对象名称 Country,second 保存“USA” 现在当我获取它的时候
我将使用 C# 和 Xamarin 制作的 iOS 应用重写到 Swift,原因很明显是 Xamarin 的定价和低文档。正在关注this tutorial因为在我的 UITableView 上包含一
假设我有一个线束二进制文件,它可以根据命令行选项产生不同的基准。我对采样这些基准非常感兴趣。 我有3个选择: 更改线束二进制文件以生成一个“性能记录”子进程,该子进程运行基准测试并进行采样 只需执行“
什么 SQL 查询会按名称查找记录,以及具有相同地址但可能不同名称的所有记录? 我有一个选民登记数据库,当我查找个人时,我还想看看还有谁在该地址登记。 我的数据库称为 voters,其中的表称为 ex
我在我的 mac 上设置了一个 Tsung 配置,并尝试在我正在开发的网站上记录一个测试。 我跑了:“tsung-recorder start”并在 firefox localhost:8090 中为
我需要将 JOOQ 的记录结果集转换为表记录列表。有什么方法可以做到吗? 最佳答案 是的,您可以使用 Result.into(Table) .一个例子: Result result = create.
我正在尝试将 CKReference 添加到云工具包中的记录,但尝试不断触发“服务记录已更改”。从我的 println 显示的控制台消息(下面的控制台消息和代码), 我正在上传带有 0 个引用的记录,
我有两个类:Artist 和 Instrument。每个 Artist 可以演奏一个或多个 Instrument。每个 Instrument 可以分配给一个或多个 Artist。所以,我设置了以下类:
我是一名优秀的程序员,十分优秀!