ECHO 不换行实现方法
我想用批处理实现向s.txt中多次分别导入文本例如:“aaaa","bbbb","cccc","dddd"
实现s.txt内效果如:
aaaabbbbccccdddd
可是echo命令每次导入的时候会强制换行,如:
aaaa
bbbb
cccc
dddd
我该怎么实现我想要的一行效果呢?谢谢!
答案:
echo做不到,不过可以执行以下语句到达到目的
>>s.txtset/p="aaaa"<nul >>s.txtset/p="bbbb"<nul >>s.txtset/p="cccc"<nul >>s.txtset/p="dddd"<nul
s.txt的内容将是aaaabbbbccccdddd
注1:“>>s.txt”这里是输出流定向的意思,把输出流重定到了s.txt文件,“<nul”则是把输入流指定成了nul,所以set/p="aaaa"就不用等待用户输入了。
其实把写文件操作放到后面更容易让人理解些:set/p="aaaa"<nul>>s.txt
注2:关于set/p="aaaa"的详细内容请查看《set命令》
实例1:
ifexist%statFile2%(>>%statFile2%set/p=,%%i<nul)else(>>%statFile2%set/p=%%i<nul)
实例2----(个人添加)
@echooff delb.txt delc.txt deld.txt ifexist"%cd%\zhI386"rd/s/q"%cd%\zhI386" mdzhI386 ::for/r"%cd%\eni386\"%%iin(*)do(echo%%i>>b.txt) for/f%%iin('dir/b%cd%\eni386\')do( echo%%i>>c.txt ifexist"%cd%\zhall\i386\%%i"(copy"%cd%\zhall\i386\%%i""%cd%\zhI386\" )else(>>d.txtset/p="zhall\i386\%%i"<nul&echo----Notexist>>d.txt) )
windows批处理之六-echo输出不换行
完整案例:
Code:
@echooff set/p="hello"<nul set/p="world"<nul echoagain echonewline
Result:
helloworldagain
newline
应用:
echooff setcsvpath=测试数据 setsqluldr=D:\sqluldr\sqluldr2sdk\sqluldr2 setsqlpath=导出模板 remsetfilename=产品行情 remsqluldr2gtcustomer/passwdfile=%csvpath%\%filename%.csvtext=csvfield=,sql=exp%filename%.sqllog=%csvpath%\%filename%.log rem remsetfilename=产品行情更新 remsqluldr2gtcustomer/passwdfile=%csvpath%\%filename%.csvtext=csvfield=,sql=exp%filename%.sqllog=%csvpath%\%filename%.log
setexpfpath=百万级 echo导出%expfpath%数据: for%%iin(%sqlpath%\%expfpath%\exp*.sql)do( set/p="导出数据:%%~ni"<nul %sqluldr%gtcustomer/passwdfile=%csvpath%\%expfpath%\%%~ni.csvtext=csvfield=,sql=%%ilog=%csvpath%\%expfpath%\%%~ni.log echo............ok. ) setexpfpath=千万级 echo导出%expfpath%数据: for%%iin(%sqlpath%\%expfpath%\exp*.sql)do( set/p="导出数据:%%~ni"<nul %sqluldr%gtcustomer/passwdfile=%csvpath%\%expfpath%\%%~ni.csvtext=csvfield=,sql=%%ilog=%csvpath%\%expfpath%\%%~ni.log echo............ok. ) pause