[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

[文本处理] xlsx用批处理进行字符串替换并保存后碰到系统无法再打开excel的情况,如何解决?

请教各位前辈:
有没有碰到过类似的问题,当用bat文件对位于D:\Program Files (x86)的excel 文件  addesss update_2021.xlsx进行字符串替换并保存后碰到系统无法再打开excel的情况,请问该如何解决:
比方说excel里边有很多列,列名字分别为以下:
woodlands drive 76        woodlands drive 66        woodlands drive 89        woodlands drive 93        woodlands drive 22        woodlands drive 25
bat文件批处理的是将  woodlands drive 全部替换为 sembawang street。


bat文件内容如下:
  1. rem 对excel文档 addesss update_2021.xlsx 指定字符串自动替换更名:
  2. @echo off
  3. setlocal enabledelayedexpansion
  4. cd /d "D:\Program Files (x86)"
  5. (for /f "tokens=1* delims=:" %%i in ('findstr /n ".*" "addesss update_2021.xlsx"') do (
  6.     set a=%%j
  7.     if "%%j"=="" (
  8.         echo;
  9.     ) else (
  10.         echo;!a:woodlands drive=sembawang street!
  11.     )
  12. ))>"addesss update_2021.tmp"
  13. move /y "addesss update_2021.tmp" "addesss update_2021.xlsx"
复制代码

批处理是不能直接处理xls和xlsx文件的。office格式的文件信息量过大。

TOP

回复 1# qspringleaf


    xlsx不是纯文本文件,建议试试PowerShell或VBS进行处理
我帮忙写的代码不需要付钱。如果一定要给,请在微信群或QQ群发给大家吧。
【微信公众号、微信群、QQ群】http://bbs.bathome.net/thread-3473-1-1.html
【支持批处理之家,加入VIP会员!】http://bbs.bathome.net/thread-67716-1-1.html

TOP

返回列表