Board logo

标题: 如何将文件文件里对应的属性值替换到XML文件里? [打印本页]

作者: sghys     时间: 2008-7-17 15:09    标题: 如何将文件文件里对应的属性值替换到XML文件里?

呵,麻烦各位大大帮忙,问题比较急(弄了半天啦都没搞好,55...)

C盘下有两个文件
文本文件connInfo.txt内容如下
loginUser=sa
loginPass=sa
targetIp=191.168.1.100
db_name=ora

XML文件内容如下
<Context>
<ResourceParams name="jdbc/oa">
  <parameter>
   <name>username</name>
   <value>!loginUser!</value>//替换这里的用户名
  </parameter>
  <parameter>
   <name>password</name>
   <value>!loginPass!</value>//替换这里的密码
  </parameter>
  <parameter>
   <name>driverClassName</name>
   <value>net.sourceforge.jtds.jdbc.Driver</value>
  </parameter>  
  <parameter>
   <name>url</name>
   <value>jdbc:jtds:sqlserver://!targetIp!:1433/!db_name!</value>//替换这里地址与名称         </parameter>
</ResourceParams>
</Context>


批处理怎么样才能生成如下XML文件,最好有完整批处理代码.谢谢各位了


<Context>
<ResourceParams name="jdbc/oa">
  <parameter>
   <name>username</name>
   <value>sa</value>
  </parameter>
  <parameter>
   <name>password</name>
   <value>sa</value>
  </parameter>
  <parameter>
   <name>driverClassName</name>
   <value>net.sourceforge.jtds.jdbc.Driver</value>
  </parameter>  
  <parameter>
   <name>url</name>
   <value>jdbc:jtds:sqlserver://191.168.1.100:1433/ora</value>      
  </parameter>
</ResourceParams>
</Context>
作者: HAT     时间: 2008-7-17 16:36

@echo off
for /f "tokens=2 delims==" %%a in ('findstr /i "loginUser" "connInfo.txt"') do set user=%%a
for /f "tokens=2 delims==" %%a in ('findstr /i "loginPass" "connInfo.txt"') do set pass=%%a
for /f "tokens=2 delims==" %%a in ('findstr /i "targetIp" "connInfo.txt"') do set ip=%%a
for /f "tokens=2 delims==" %%a in ('findstr /i "db_name" "connInfo.txt"') do set name=%%a
change "test.xml" /from "!loginUser!" /to "%user%"
change "test.xml" /from "!loginPass!" /to "%pass%"
change "test.xml" /from "!targetIp!" /to "%ip%"
change "test.xml" /from "!db_name!" /to "%name%"
change.exe
http://upload.cn-dos.net/img/427.zip
作者: sghys     时间: 2008-7-17 17:40
呵,楼上的谢了

自己也研究了一下:

批处理如下:
@echo off&setlocal enabledelayedexpansion
for /f "delims== tokens=1,2*" %%a in (test.txt) do (
if "%%a"=="loginUser" set loginUser=%%b
if "%%a"=="loginPass" set loginPass=%%b
if "%%a"=="targetIp" set targetIp=%%b
if "%%a"=="db_name" set db_name=%%b
)
echo %loginUser%
echo %loginPass%
echo %targetIp%
echo %db_name%

set loginUser=%loginUser%
set loginPass=%loginPass%
set targetIp=%targetIp%
set db_name=%db_name%

if not exist contract.xml goto 2
del contract.xml
:2
for /f "delims=" %%i in (contract_conf.xml) do (echo.%%i>>contract.xml)
pause

text.txt内容如下:
loginUser=sa
loginPass=sa
targetIp=192.168.1.100
db_name=ora

contract_conf.xml内容如下:
<Context>
<ResourceParams>
  <parameter>
   <name>username</name>
   <value>!loginUser!</value>
  </parameter>
  <parameter>
   <name>password</name>
   <value>!loginPass!</value>
  </parameter>
  <parameter>
   <name>driverClassName</name>
   <value>net.sourceforge.jtds.jdbc.Driver</value>
  </parameter>  
  <parameter>
   <name>url</name>
   <value>jdbc:jtds:sqlserver://!targetIp!:1433/!db_name!</value>      
  </parameter>
</ResourceParams>
</Context>
作者: lxmxn     时间: 2008-7-21 06:15
没必要搞那么复杂。
@echo off & Setlocal EnableDelayedExpansion

for /f "delims=" %%$ in (connInfo.txt) do set %%$
for /f "delims=" %%@ in (contract_conf.xml) do echo.%%@