微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Windows – 批量文件拆分.csv文件

我有一个非常大的.csv文件(> 500mb),我希望在命令提示符下将其分解成较小的.csv文件。 (基本上试图在Windows中找到一个linux“split”功能

这必须是一个批处理脚本,因为我的机器只安装了Windows,请求软件是一个痛苦。我遇到了一些示例代码(http://forums.techguy.org/software-development/1023949-split-100000-line-csv-into.html),但是,当我执行批处理时,它不起作用。我得到的是一个输出文件,只有125kb,当我请求它解析每2万行。

有人遇到过类似的问题,您是如何解决问题的?

试试这个:
@echo off
setLocal EnableDelayedExpansion

set limit=20000
set file=export.csv
set lineCounter=1
set filenameCounter=1

set name=
set extension=
for %%a in (%file%) do (
    set "name=%%~na"
    set "extension=%%~xa"
)

for /f "tokens=*" %%a in (%file%) do (
    set splitFile=!name!-part!filenameCounter!!extension!
    if !lineCounter! gtr !limit! (
        set /a filenameCounter=!filenameCounter! + 1
        set lineCounter=1
        echo Created !splitFile!.
    )
    echo %%a>> !splitFile!

    set /a lineCounter=!lineCounter! + 1
)

如上面的代码所示,它将原始的csv文件分割成多个csv文件,限制为20 000行。所有你需要做的是更改!文件!和!限制!变量相应。希望它有帮助。

原文地址:https://www.jb51.cc/windows/372743.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐