标题: [文件操作] [已解决] 批处理for命令delims如何分割带空格字符? [打印本页]
作者: 202048 时间: 2022-10-2 15:44 标题: [已解决] 批处理for命令delims如何分割带空格字符?
本帖最后由 202048 于 2022-12-5 09:32 编辑
*一批目录部分例如下:
ACC Y01
CAY Y02
菊花 Y03
AC 梅花 Y04
.......
*需求:名称从空格Y,进行分割,存入csv表格,目录名存在多个Y,需以空格Y分割
*水品有限,写了部分,还请大佬帮忙修改完善.- @echo off
- echo 全名,简名,序号>name.csv
- for /f "delims=" %%a in ('dir /ad /b') do (
- for /f "tokens=1,2 delims=Y" %%b in ("%%a") do (
- echo %%a,%%b,%%c>>name.csv
- )
- )
- pause
复制代码
在本论坛找了下参考
http://www.bathome.net/viewthread.php?tid=7596&highlight=delims
扒拉了半天变量,还是玩不明白 希望大佬指点下
作者: qixiaobin0715 时间: 2022-10-2 16:07
没有明白你的意思。你例子中的目录,存为csv表格是什么样式?
作者: 202048 时间: 2022-10-2 16:13
回复 2# qixiaobin0715
例:ACC Y01这个目录名字
分三列存入csv文件
第一列 第二列 第三列
ACC Y01 ACC 01
作者: qixiaobin0715 时间: 2022-10-2 16:23
存为ANSI编码- @echo off
- setlocal enabledelayedexpansion
- (echo,全名,简名,序号
- for /d %%i in (*) do (
- set "str=%%i"
- set "str=!str: Y=/!"
- for /f "tokens=1* delims=/" %%j in ("!str!") do (
- echo,%%i,%%j,%%k
- )
- ))>name.csv
- pause
复制代码
作者: 202048 时间: 2022-10-2 17:00
回复 4# qixiaobin0715
大佬,我的目的也是忽略大小写Y,但按我理解应该会有参数之类,你的运行效果很好,但我好像没看到什么参数,为啥却可以忽略大小写啊,好神奇
作者: Batcher 时间: 2022-10-3 10:32
回复 5# 202048
参考:https://mp.weixin.qq.com/s/tPzWXXgS0QKt9Oo77_K03A
set "NewName=!OldName:%%j=%%j!"
在使用set命令进行字符串替换的时候,第二个等号左边的字母(红色变量%%j的值)不区分大小写,第二个等号右边的字母(绿色变量%%j的值)区分大小写。
作者: 202048 时间: 2022-10-3 15:01
回复 6# Batcher
感谢大佬帮忙
欢迎光临 批处理之家 (http://bbs.bathome.net/) |
Powered by Discuz! 7.2 |