[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

[文件操作] [已解决] 批处理for命令delims如何分割带空格字符?

本帖最后由 202048 于 2022-12-5 09:32 编辑

*一批目录部分例如下:

ACC Y01
CAY Y02
菊花 Y03
AC 梅花 Y04
.......

*需求:名称从空格Y,进行分割,存入csv表格,目录名存在多个Y,需以空格Y分割

*水品有限,写了部分,还请大佬帮忙修改完善.
  1. @echo off
  2. echo 全名,简名,序号>name.csv
  3. for /f "delims=" %%a in ('dir /ad /b') do (
  4.     for /f "tokens=1,2 delims=Y" %%b in ("%%a") do (
  5.    echo %%a,%%b,%%c>>name.csv
  6. )  
  7. )
  8. pause
复制代码
在本论坛找了下参考
http://www.bathome.net/viewthread.php?tid=7596&highlight=delims

扒拉了半天变量,还是玩不明白 希望大佬指点下
无个性,不签名

没有明白你的意思。你例子中的目录,存为csv表格是什么样式?

TOP

回复 2# qixiaobin0715


例:ACC Y01这个目录名字
分三列存入csv文件

  第一列       第二列        第三列
ACC Y01      ACC            01
无个性,不签名

TOP

存为ANSI编码
  1. @echo off
  2. setlocal enabledelayedexpansion
  3. (echo,全名,简名,序号
  4. for /d %%i in (*) do (
  5.     set "str=%%i"
  6.     set "str=!str: Y=/!"
  7.     for /f "tokens=1* delims=/" %%j in ("!str!") do (
  8.         echo,%%i,%%j,%%k
  9.     )
  10. ))>name.csv
  11. pause
复制代码
1

评分人数

    • 202048: 大佬真强,感谢感谢技术 + 1

TOP

回复 4# qixiaobin0715


    大佬,我的目的也是忽略大小写Y,但按我理解应该会有参数之类,你的运行效果很好,但我好像没看到什么参数,为啥却可以忽略大小写啊,好神奇
无个性,不签名

TOP

回复 5# 202048


参考:https://mp.weixin.qq.com/s/tPzWXXgS0QKt9Oo77_K03A

set "NewName=!OldName:%%j=%%j!"
在使用set命令进行字符串替换的时候,第二个等号左边的字母(红色变量%%j的值)不区分大小写,第二个等号右边的字母(绿色变量%%j的值)区分大小写。
1

评分人数

我帮忙写的代码不需要付钱。如果一定要给,请在微信群或QQ群发给大家吧。
【微信公众号、微信群、QQ群】http://bbs.bathome.net/thread-3473-1-1.html
【支持批处理之家,加入VIP会员!】http://bbs.bathome.net/thread-67716-1-1.html

TOP

回复 6# Batcher

感谢大佬帮忙
无个性,不签名

TOP

返回列表