中国DOS联盟

-- 联合DOS 推动DOS 发展DOS --

联盟域名:www.cn-dos.net 论坛域名:www.cn-dos.net/forum
DOS,代表着自由开放与发展,我们努力起来,学习FreeDOS和Linux的自由开放与GNU精神,共同创造和发展美好的自由与GNU GPL世界吧!

中国DOS联盟论坛
现在时间是 2026-06-14 19:05
中国DOS联盟论坛 » DOS批处理 & 脚本技术(批处理室) » FOR循环中如何取文件中一行用|分割的多个值?
楼 主 FOR循环中如何取文件中一行用|分割的多个值? 发表于 2006-09-27 03:14 ·  中国 浙江 杭州 电信
初级用户
积分 28
发帖 10
注册 2006-09-19 13:29
UID 63072
性别 男
状态 离线
有一个文本a.txt

435241|阳新|8区
435250|白沙|8区
****

怎么能够取到"|"分割的各个值?
2 发表于 2006-09-27 03:20 ·  中国 江苏 苏州 电信
银牌会员
★★★
积分 1,181
发帖 533
注册 2006-08-14 12:54
UID 60484
状态 离线
for /f "tokens=1,2,3 delims=|" %%i in (t.txt) do (...)
3 发表于 2006-09-27 04:35 ·  中国 浙江 杭州 电信
初级用户
积分 28
发帖 10
注册 2006-09-19 13:29
UID 63072
性别 男
状态 离线
谢谢你的回复

%%i 指的是第几个值?第一个还是第二个还是第三个?
4 发表于 2006-09-27 04:37 ·  中国 北京 联通
银牌会员
★★★
努力做坏人
积分 1,185
发帖 438
注册 2006-08-28 12:00
UID 61449
来自 北京
状态 离线
%%i 第一个
%%j 第二个
%%k 第三个
我今后在论坛的目标就是做个超级坏人!!!
5 发表于 2006-09-27 08:05 ·  中国 甘肃 张掖 电信
金牌会员
★★★★
积分 4,103
发帖 1,744
注册 2006-01-20 13:00
UID 49241
性别 男
来自 甘肃.临泽
状态 离线
楼主先 for /? 看看
6 发表于 2006-09-27 08:47 ·  中国 浙江 杭州 电信
初级用户
积分 28
发帖 10
注册 2006-09-19 13:29
UID 63072
性别 男
状态 离线
Originally posted by pip at 2006-9-27 04:37:
%%i 第一个
%%j 第二个
%%k 第三个



%%i ,%%j ,%%k 中i j k变量是随便的吗?随便的吗?还是确定顺序的?

我是菜鸟,虚心求助
7 发表于 2006-09-27 08:58 ·  中国 浙江 杭州 电信
初级用户
积分 28
发帖 10
注册 2006-09-19 13:29
UID 63072
性别 男
状态 离线
我写的在这里,但是执行总是失败:

for /f "tokens=1,2,3 delims=|" %%i in (txip.txt)

do ( echo 'update dzhd_t_txfjxx set v_ip=%%k where c_jgbh=%%i and c_txdm=%%j ;')

txip.txt的内容为:
31001402|07|10.138.9.165
31001402|05|10.238.60.81
31001402|06|10.138.9.164
31002001|05|10.138.9.37
31002001|06|10.138.9.38
31002801|01|10.138.13.10
31000903|01|10.138.20.68
31000903|03|10.138.20.74

错误信息为:
E:\ftp>sql.bat
命令语法不正确。

E:\ftp>for /f "tokens=1,2,3 delims=|" %i in (txip.txt)
8 发表于 2006-09-27 09:07 ·  中国 湖南 娄底 新化县 电信
银牌会员
★★★
积分 1,218
发帖 485
注册 2006-07-21 21:24
UID 58987
来自 湖南.娄底
状态 离线
%%i, %%j, %%k是一个次序问题; 如果初始变量定义为%%a, 那么排序将会是%%a, %%b, %%c, %%d...; 同样如果初始变量为%%0, 排序就是%%0, %%1, %%2...

这和FOR语句提取到的字符或字符串的基数有关, 每提取到一个字符或字符串就赋给下一个变量. 依此类推.

当然也有个数限制, 如果是字母定义的变量他们的数量不能超过26个(a-z).

用阿拉伯数字定义变量最多不能超过10个(0-9).
9 发表于 2006-09-27 10:00 ·  中国 广东 佛山 广东睿江科技有限公司
荣誉版主
★★★★
batch fan
积分 5,226
发帖 1,737
注册 2006-03-10 00:38
UID 51697
来自 成都
状态 离线
Originally posted by pengfei at 2006-9-27 09:07:
当然也有个数限制, 如果是字母定义的变量他们的数量不能超过26个(a-z).

  个数有限制的说法是正确的,但是字母变量的个数不能超过26个就不准了,因为for语句中的字母变量是要区分大小写的,所以字母变量的个数应该不能超过52个。
尺有所短,寸有所长,学好CMD没商量。
考虑问题复杂化,解决问题简洁化。
10 发表于 2006-09-27 10:10 ·  中国 湖南 娄底 新化县 电信
银牌会员
★★★
积分 1,218
发帖 485
注册 2006-07-21 21:24
UID 58987
来自 湖南.娄底
状态 离线
是的, 那么作为52个变量的赋值规律是, 先从小写赋值完成再赋给大写吗?

帮助中也提到过一行指定最多26个字符, 而提到的不能同时使用52个以上, 由于没有深究也就没有提出来.

[ Last edited by pengfei on 2006-9-27 at 10:17 ]
11 发表于 2006-09-27 10:28 ·  中国 广东 佛山 广东睿江科技有限公司
荣誉版主
★★★★
batch fan
积分 5,226
发帖 1,737
注册 2006-03-10 00:38
UID 51697
来自 成都
状态 离线
Originally posted by pengfei at 2006-9-27 10:10:
是的, 那么作为52个变量的赋值规律是, 先从小写赋值完成再赋给大写吗?

帮助中也提到过一行指定最多26个字符, 而提到的不能同时使用52个以上, 由䠮..

  这个问题倒没深入地想过,推测是这样的:如果一开始就用了小写来定变量名,那么,同一层上的for后面的变量最多应该只能到z,如果是大写的话,最多就只能到Z,也就是说,变量名的大小写应该是从一而终的,不可混用的,否则,帮助里也就不会有 一行指定最多26个字符, 而提到的不能同时使用52个以上 这个提法了。仅是推测而已,有了解的请再深入地分析一下吧。
尺有所短,寸有所长,学好CMD没商量。
考虑问题复杂化,解决问题简洁化。
12 发表于 2006-09-27 11:08 ·  中国 湖南 娄底 新化县 电信
银牌会员
★★★
积分 1,218
发帖 485
注册 2006-07-21 21:24
UID 58987
来自 湖南.娄底
状态 离线
Originally posted by namejm at 2006-9-27 10:28:

  这个问题倒没深入地想过,推测是这样的:如果一开始就用了小写来定变量名,那么,同一层上的for后面的变量最多应该只能到z,如果是大写皠...


我想是这样的吧, 一个循环中使用字母做变量不能为52个以上, 变量名只能为单一字母分大小写, 这样系统能够正常处理的字母变量就不能大于52个.

如果加上数字, 在全局中变量最多可以使用62个, 而FOR提取文本行赋于变量数不能大于26个(a-z)或(A-Z).
13 发表于 2006-09-27 20:24 ·  中国 浙江 杭州 电信
初级用户
积分 28
发帖 10
注册 2006-09-19 13:29
UID 63072
性别 男
状态 离线
大家帮帮忙看看我到底错在哪里啊?

for /f "tokens=2,3* delims=|" %%i in (txip1.txt)

do ( echo 'update dzhd_t_txfjxx set v_ip=%%k where c_jgbh=%%i and c_txdm=%%j ;') >a.sql

提示为"E:\ftp>rem for /f "tokens=1,2,3 delims=|" %0 in (txip1.txt)
命令语法不正确。

E:\ftp>for /f "tokens=2,3* delims=|" %i in (txip1.txt)"
14 发表于 2006-09-27 20:58 ·  中国 江苏 苏州 电信
银牌会员
★★★
积分 1,181
发帖 533
注册 2006-08-14 12:54
UID 60484
状态 离线
echo 那行的 () 打错了, >a.sql 应该和 ECHO 在一起的。
15 发表于 2006-09-28 04:20 ·  中国 江苏 苏州 电信
中级用户
★★
过度热情
积分 321
发帖 139
注册 2006-03-21 17:19
UID 52521
性别 男
状态 离线
刚才帮你写的代码。 呵呵。有兴趣看看
Function splitfile(strFile)
Const ForReading = 1,ForWriting=2
Dim i, retstring
Set fso = CreateObject("Scripting.FileSystemObject")
Set theFile = fso.OpenTextFile(strFile, ForReading, False)
Do While theFile.AtEndOfStream <> True
retstring=Split(theFile.ReadLine,"|",-1,1)
For i=0 to UBound(retstring)
wscript.echo retstring(i)
Next
loop
theFile.Close
End Function
知识在于不断积累
论坛跳转: