将多个文本文件合并为一个



我已经搜索了万维网,似乎找不到任何解决我问题的方法!我想合并多个文本文件。

展示例子比解释我为什么要这样做更容易。

第一个文件如下所示:

John
Paul
Mark
Sam
Herold

此文件用作"主键"。

其余

文件包含每个项目的数据,如下所示。程序每小时将此数据生成到一个新文件中。

4
10
20
5
200

我最熟悉Windows批处理文件,所以我尝试编写这样的东西:

for /f "tokens=*" %%A in (file1.txt) do 
    (for /f "tokens=*" %%B in (file2.txt) do (echo %%A,%%B>>combined.txt))

不幸的是,这将每一个价值都写给了每个人。如果这按预期工作,最终结果将是这样的:

John,4,2,6,9,1,2,5,6,12,51,53,3,6,7,8,1,4,7,2,743,21,4,7,5
Paul,10,5,6,1,7,9,34,56,1,76,48,23,222,12,54,67,23,652,1,6,71,3,6,4

等等。

我使用的软件以这种格式显示数据,并且无法更改。我愿意接受任何和所有建议。

您可以通过标准句柄读取 Batch 程序中的多个输入文件。请记住,0 是 Stdin,1 是 Stdout,2 是 Stderr,但这留下了 3 到 9 个可用的句柄!下面的批处理文件与两个文件的内容进行文件合并;当然,这种方法最多可以组合8个文件。

@echo off
setlocal EnableDelayedExpansion
Rem First file is read with FOR /F command
Rem Second file is read via standard handle 3
3< file2.txt (for /F "delims=" %%a in (file1.txt) do (
   Rem Read next line from file2.txt
   set /P line2=<&3
   Rem Echo lines of both files
   echo %%a,!line2!
))

更多详情请见:http://www.dostips.com/forum/viewtopic.php?f=3&t=3126

unix 命令粘贴可能是您要查找的内容。另请参阅StackOverflow上的此问题。

你可以

这样做:

paste -d, file*.txt > combined.txt

如果您有paste可用。 您可能需要安装 cygwin,或在 *nix 机器上工作。 (你确实说过你对所有建议都持开放态度! 这依赖于按顺序命名的数据文件。 如果你想调整顺序,你可以把它拼出来,而不是使用glob。

相关内容

  • 没有找到相关文章