如何用vs2008流生成excel文件

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何用vs2008流生成excel文件相关的知识,希望对你有一定的参考价值。

参考技术A 假如你用VS2008
写的Win32
SDK程序,那么请进行如下操作:在"Solution
Explorer"里,右键点击项目,然后在弹出菜单内指向"Add",在弹出子菜单内选择"Resource"(资源),然后会弹出"Add
Resource"对话框,然后点"Version",然后点"New",这时会添加一个版本描述资源,exe文件的任何信息都在此描述。
如果是C#
程序(.Net
Framework),那么在项目,属性(或者用Alt+F7快捷键),Application里面,点击"Assembly
Information..."按钮来编辑可执行文件描述。

无法从原始流生成正确的 wav 文件

【中文标题】无法从原始流生成正确的 wav 文件【英文标题】:Fail to generate correct wav file from raw stream 【发布时间】:2012-12-12 12:57:45 【问题描述】:

我捕获了原始音频数据流及其 WAVEFORMATEXTENSIBLE 结构。 WAVEFORMATEXTENSIBLE如下图所示:

按照 wav 文件的standard,我尝试将原始位写入 wav 文件。 我要做的是:

    写“RIFF”。

    写一个 DWORD。 (文件大小 - sizeof("RIFF") - sizeof(DWORD))。

=== WaveFormat 块 ===

    写“WAVEfmt”

    写一个 DWORD。 (WAVEFORMATEXTENSIBLE 结构的大小)

    编写 WAVEFORMATEXTENSIBLE 结构。

=== 事实块 ===

    写“事实”

    写一个 DWORD。 (四)

    写一个 DWORD。 (流中的样本数,应为 sizeof(rawdata)*8/wBitsPerSample )。

=== 数据块 ===

    写“数据”

    写一个 DWORD(原始数据的大小)

    写入原始数据。

通过上述步骤得到wav文件后,我用媒体播放器播放了wav文件,没有声音,用大胆播放会给我一个失真的声音,我可以听到这是我想要的正确音频,但是声音因噪音而失真。

原始数据可以在here找到

我生成的wav文件是here

这让我很困惑,因为当我使用相同的方法将 IEEE-float 数据转换为 wav 文件时,它工作得很好。

【问题讨论】:

您确定您的原始数据是 32 位的吗? 应该是,因为WAVEFORMATEX结构说是,而WAVEFORMATEX是从IAudioClient获取的。 但它是 32 位整数还是 32 位浮点数?这可能是问题的原因。您需要检查您的子类型 GUID 是否正确(PCM 或 FLOAT) 我不太明白,这些数据是通过hook到IAudioRenderClient中获取的,并拦截getBuffer和releaseBuffer方法。我从对应的 IAudioClient 获得了 WAVEFORMATEX 结构,我想我应该假设 WAVEFORMATEX 是正确的并按原样使用。 我不确定为什么 IAudioClient 上的 initialize 方法需要一个waveformatex 参数,GetMixFormat 方法不是很容易获得它吗?示例代码总是从IAudioClient的GetMixFormat中获取waveformatex,然后传回IAudioClient的initialize方法。 【参考方案1】:

我想通了,似乎 IAudioRenderClient 中的 getbuffer releasebuffer 循环将原始数据的格式与传递给 IAudioClient 的初始化方法的格式相同。

在我的例子中,IAudioClient 中的 GetMixFormat 与传递给 initialize 方法的格式不同。我认为 GetMixFormat 得到了设备支持的格式。

IAudioClient 应该已经完成​​了从初始化格式到混合格式的格式转换。我拦截了初始化方法,获取了格式,它就像一个魅力。

【讨论】:

【参考方案2】:

我正在拦截 WASAPI 以访问音频数据并面临完全相同的问题,即从数据生成的音频文件听起来像是正确的内容,但在某种程度上非常嘈杂,尽管帧速率、采样宽度、通道数等。设置正确。

WAVEFORMATEXTENSIBLE 的 SubFormat 字段显示数据实际上是 KSDATAFORMAT_SUBTYPE_IEEE_FLOAT,而我最初将其视为整数。根据this page,KSDATAFORMAT_SUBTYPE_IEEE_FLOAT 等价于 WAVEFORMATEX 中的 WAVE_FORMAT_IEEE_FLOAT。因此,将 wav 文件的 fmt 块(通常从第 20 位开始)中的“音频格式”设置为 WAVE_FORMAT_IEEE_FLOAT(即 3)解决了这个问题。记得把它放在小端。

音频格式的原始值 修改后

【讨论】:

以上是关于如何用vs2008流生成excel文件的主要内容,如果未能解决你的问题,请参考以下文章

java中把列表用流生成了Excel表格中的时间显示问题

spring mvc 读取数据库的二进制流生成excel文件

如何用MFC打印指定excel

如何用matlab把txt或Excel格式的数据转换成mat格式

如何用VBA将excel表导出成文本类型的文件?

如何用Java导出数据存到excel里面