C:\_G\WWW\~ELISANET\INFO\tscmd034.html
<http://www.elisanet.fi/tsalmi/info/tscmd034.html>
Copyright © 2003- by Prof. Timo Salmi  
Last modified Fri 12-Oct-2018 02:41:36

 
Assorted NT/2000/XP/.. CMD.EXE Script Tricks
From the html version of the tscmd.zip 1cmdfaq.txt file
To the Description and the Index
 

This page is edited from the 1cmdfaq.txt faq-file contained in my tscmd.zip command line interface (CLI) collection. That zipped file has much additional material, including a number of detached .cmd script files. It is recommended that you also get the zipped version as a companion.

Please see "The Description and the Index page" for the conditions of usage and other such information.



34} How can I remove the quote characters from a line?

Below is a demonstration
  @echo off & setlocal enableextensions
  ::
  :: Set up a test

  set line_="54321","1","3","1234567890122","","","","","",""
  echo %line_%
  ::
  :: Omit the quotes

  set line_=%line_:"=%
  ::
  :: List the first four fields

  for /f "tokens=1-4 delims=," %%f in ('echo %line_%') do (
    call :ListThem %%f %%g %%h %%i)
  endlocal & goto :EOF
  :: ======================================================
  :ListThem
  setlocal enableextensions
    echo.%1
    echo.%2
    echo.%3
    echo.%4
  endlocal & goto :EOF

The output will be
  D:\TEST>batfaq
  "54321","1","1","1234567890122","","","","","",""
  54321
  1
  3
  1234567890122

Using SED
  @echo off & setlocal enableextensions
  ::
  :: Set up a test

  set line_="54321","1","3","1234567890122","","","","","",""
  echo %line_%
  echo %line_%|sed -e "s/\x22//g"
  for /f "tokens=* delims=" %%a in (
    'echo %line_%^|sed -e "s/\x22//g"') do set lineNQ=%%a
  echo %lineNQ%
  endlocal & goto :EOF

The output is
  C:\_D\TEST>cmdfaq
  "54321","1","3","1234567890122","","","","","",""
  54321,1,3,1234567890122,,,,,,
  54321 1 3 1234567890122      
1) Note the different outcomes. In FOR /F the commas (,) count as default delimiters.
2) \x22 is hex for "

A Visual Basic Script (VBScript) aided solution (tolerating poison characters):
  @echo off & setlocal enableextensions
  rem C:\_M\TEST\CMDTEST.CMD
  ::
  :: Set up a test

  set line_="54321","1","3","1234567890122","","","","","",""
  echo %line_%
  ::
  :: Build a Visual Basic Script

  set skip=
  set vbs_=%temp%\tmp$$$.vbs
  >"%vbs_%" findstr "'%skip%VBS" "%~f0"
  ::
  :: Run it with Microsoft Windows Script Host Version 5.6

  for /f "tokens=* delims=" %%a in ('
    echo %line_%^|cscript //nologo "%vbs_%"') do (
    set lineNQ=%%a)
  ::
  :: Clean up

  for %%f in ("%vbs_%") do if exist %%f del %%f
  ::
  :: Display the result

  echo %lineNQ%
  endlocal & goto :EOF
  '
  '............................................
  'The Visual Basic Script
  '

  Do While Not WScript.StdIn.AtEndOfStream 'VBS
    str = WScript.StdIn.ReadLine 'VBS
    str = Replace (str, Chr(34),"") 'VBS
    WScript.StdOut.WriteLine str 'VBS
  Loop 'VBS

  C:\_M\TEST>cmdtest
  "54321","1","3","1234567890122","","","","","",""
  54321 1 3 1234567890122      

For removing the quotes from an entire file, see the VBS solution in item #152.

[Previous] [Next]

C:\_G\WWW\~ELISANET\INFO\tscmd034.html
C:\_G\WWW\~ELISANET\FTPCMD\TSALMI.CMD /tscmd034
http://www.elisanet.fi/tsalmi/info/tscmd034.html
file:///c:/_g/www/~elisanet/info/tscmd034.html