批量合并CSV文件(无重复项)

时间:2015-03-18 11:42:35

标签: csv batch-file windows-7 merge command-prompt

我想使用批处理合并两个类似的CSV文件。我发现一个文件工作正常,现在不是。这可能是因为重命名了所使用的CSV文件。

我想要下面演示的内容:

文件1:

name1,group1,data1
name2,group2,data2
name3,group3,data3

文件2:

name1,group1,data1,time1
name2,group2,data2,time2

合并文件:

name1,group1,data1,time1
name2,group2,data2,time2
name3,group3,data3

(请注意,第四列未按名称3填写,随后未在文件2中填写。)

以下代码经过修改:http://www.experts-exchange.com/OS/Microsoft_Operating_Systems/MS_DOS/Q_27694997.html

@echo off

set "tmpfile=%temp%\importlist.tmp"
set "csvfile=importlist.csv"
copy nul "%tmpfile%" >nul

echo.
echo Processing all CSV files...
set "header="
for %%a in (%1) do (
    if not "%%a"=="%csvfile%" (
        set /p =Processing %%a...<nul
        for /f "tokens=1* usebackq delims=," %%b in ("%%a") do (
            if /i "%%b"=="Keyword" (
                if not defined header (
                    set /p =Found header...<nul
                    set "header=%%b,%%c"
                )
            ) else (
                title [%%a] - %%b,%%c
                findstr /b /c:"%%b" /i "%tmpfile%">nul || echo %%b,%%c>>"%tmpfile%"
            )
        )
        echo OK
    )
)
echo Finished processing all CSV files

echo.
echo Creating %csvfile%
echo %header%>"%csvfile%"

set /p =Sorting data...<nul
sort "%tmpfile%">>"%csvfile%"
echo OK
del "%tmpfile%"

echo Finished!
title Command Prompt
exit /b

问题在于,执行时只会创建一个带有第一个文件而不是第二个文件的所有数据的排序CSV。

我试图通过在参数(%1 - “目录* .csv”)周围加上引号来使其工作无效。

1 个答案:

答案 0 :(得分:1)

你可以试试这个

@echo off &setlocal disabledelayedexpansion
for /f "delims=" %%a in (file1.csv) do set "@%%~a=7"
for /f "tokens=1-4delims=," %%a in (file2.csv) do (
    set "lx1=@%%~a,%%~b,%%~c"
    setlocal enabledelayedexpansion
    if defined !lx1! (
        endlocal
        set "@%%~a,%%~b,%%~c="
    ) else (
        endlocal
    )
    set "@%%~a,%%~b,%%~c,%%~d=4"
)
(for /f "delims==@" %%a in ('set @') do echo %%~a)>merge.csv
type merge.csv

如果您的数据中包含=@,则无效。