Board logo

标题: FOR循环中如何取文件中一行用|分割的多个值? [打印本页]

作者: tomorrower     时间: 2006-9-27 03:14    标题: FOR循环中如何取文件中一行用|分割的多个值?

有一个文本a.txt

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

怎么能够取到"|"分割的各个值?
作者: NaturalJ0     时间: 2006-9-27 03:20
for /f "tokens=1,2,3 delims=|" %%i in (t.txt) do (...)
作者: tomorrower     时间: 2006-9-27 04:35
谢谢你的回复

%%i 指的是第几个值?第一个还是第二个还是第三个?
作者: 9527     时间: 2006-9-27 04:37
%%i  第一个
%%j  第二个
%%k 第三个
作者: vkill     时间: 2006-9-27 08:05
楼主先 for  /?  看看
作者: tomorrower     时间: 2006-9-27 08:47


  Quote:
Originally posted by pip at 2006-9-27 04:37:
%%i  第一个
%%j  第二个
%%k 第三个

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

我是菜鸟,虚心求助
作者: tomorrower     时间: 2006-9-27 08:58
我写的在这里,但是执行总是失败:

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)
作者: pengfei     时间: 2006-9-27 09:07
%%i, %%j, %%k是一个次序问题;  如果初始变量定义为%%a, 那么排序将会是%%a, %%b, %%c, %%d...;  同样如果初始变量为%%0, 排序就是%%0, %%1, %%2...

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

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

用阿拉伯数字定义变量最多不能超过10个(0-9).
作者: namejm     时间: 2006-9-27 10:00


  Quote:
Originally posted by pengfei at 2006-9-27 09:07:
当然也有个数限制, 如果是字母定义的变量他们的数量不能超过26个(a-z).

  个数有限制的说法是正确的,但是字母变量的个数不能超过26个就不准了,因为for语句中的字母变量是要区分大小写的,所以字母变量的个数应该不能超过52个。
作者: pengfei     时间: 2006-9-27 10:10
是的, 那么作为52个变量的赋值规律是, 先从小写赋值完成再赋给大写吗?

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

[ Last edited by pengfei on 2006-9-27 at 10:17 ]
作者: namejm     时间: 2006-9-27 10:28


  Quote:
Originally posted by pengfei at 2006-9-27 10:10:
是的, 那么作为52个变量的赋值规律是, 先从小写赋值完成再赋给大写吗?

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

  这个问题倒没深入地想过,推测是这样的:如果一开始就用了小写来定变量名,那么,同一层上的for后面的变量最多应该只能到z,如果是大写的话,最多就只能到Z,也就是说,变量名的大小写应该是从一而终的,不可混用的,否则,帮助里也就不会有 一行指定最多26个字符, 而提到的不能同时使用52个以上 这个提法了。仅是推测而已,有了解的请再深入地分析一下吧。
作者: pengfei     时间: 2006-9-27 11:08


  Quote:
Originally posted by namejm at 2006-9-27 10:28:

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

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

如果加上数字, 在全局中变量最多可以使用62个, 而FOR提取文本行赋于变量数不能大于26个(a-z)或(A-Z).
作者: tomorrower     时间: 2006-9-27 20:24
大家帮帮忙看看我到底错在哪里啊?

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)"
作者: NaturalJ0     时间: 2006-9-27 20:58
echo 那行的 () 打错了, >a.sql 应该和 ECHO 在一起的。
作者: piziliu2004     时间: 2006-9-28 04:20
刚才帮你写的代码。 呵呵。有兴趣看看
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
作者: tomorrower     时间: 2006-9-28 05:12


  Quote:
Originally posted by NaturalJ0 at 2006-9-27 20:58:
echo 那行的 () 打错了, >a.sql 应该和 ECHO 在一起的。

这样也不对:
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>sql.bat
命令语法不正确。

E:\ftp>for /f "tokens=2,3* delims=|" %i in (txip1.txt)
作者: tomorrower     时间: 2006-9-28 05:13


  Quote:
Originally posted by piziliu2004 at 2006-9-28 04:20:
刚才帮你写的代码。 呵呵。有兴趣看看
Function splitfile(strFile)
Const ForReading = 1,ForWriting=2
Dim i, retstring
Set fso = CreateObject("Scripting.FileSystemObject" ...

谢谢你热情帮助!
但是我的水平实在不好,能解释一下吗?
作者: pengfei     时间: 2006-9-28 05:42


  Quote:
Originally posted by tomorrower at 2006-9-28 05:12:



这样也不对:
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)



提示为:
...

一楼代码的问题的确出在那个重定向不在FOR语句执行范围内.

而这里改过的代码也不对, 建议for /?看看!

代码修改如下:
@echo off
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
)
pause

发过贴才发现, 楼主的原意不是这样的>a.sql这一句为覆盖, 楼主可能是要追加>>a.sql

[ Last edited by pengfei on 2006-9-28 at 05:48 ]
作者: jieok3375     时间: 2006-10-16 00:41
学习中……
作者: mydoslg     时间: 2006-10-16 17:08
你的tokens不应为2,3吧,要不就把%i变一下
作者: bd123456789     时间: 2007-7-5 09:52
呵呵,如果令牌大于62个,如有100个,那么该怎么办呢?