抱歉,第 (n+1) 次打扰您搜索和替换为批处理脚本。 我有文本文件(实际上是 PS 文件)(大约 10kB-3MB),我需要在其中替换几个数字。
我想这应该很容易。 我在 Stackoverflow 上找到了很多脚本,但到目前为止它们都没有正常工作。如果我忽略了“正在工作的”,请告诉我。
我试过的最后一个:
@echo off
setlocal DisableDelayedExpansion
set OutputFile=%1
set OutputFile=%OutputFile:"=%
set InputFile=%OutputFile%.tmp
set SearchString=636170656C6C6133
set ReplaceString=636170656C6C6134
rem write empty file
type NUL > %OutputFile%
for /f "tokens=1,* delims=¶" %%A in ( '"type %InputFile%"') do (
SET string=%%A
setlocal EnableDelayedExpansion
SET modified=!string:%SearchString%=%ReplaceString%!
echo !modified!>>%OutputFile%
endlocal
)
del %InputFile%
首先,它看起来很慢(!)。我可以在磁盘上看到文件大小是如何增加的。 数字的出现似乎被替换了。但是,文件已更改,我可以从不同的文件大小轻松看出这一点。据我所知,空行、感叹号和以分号开头的行都被跳过了。这完全弄乱了我的文件。 如何避免这种情况? 如果我用 Perl 做同样的事情,我真的只会改变数字,没有别的。但是,我不想也不能使用 Perl。我也不想使用其他额外的程序或 Windows-Powershell,因为它也应该适用于旧系统。 有什么办法可以用一个简单的 Windows 批处理脚本来实现吗? 谢谢!
最佳答案
我相信以下是一个有效的 bat 脚本,除了所需的数字更改外,不应进行任何更改:
@echo off
setlocal DisableDelayedExpansion
set "out=%~1"
set "in=%out%.tmp"
set "find=636170656C6C6133"
set "repl=636170656C6C6134"
>"%out%" (
for /f "delims=" %%A in ('findstr /n "^" "%in%"') do (
set "str=%%A"
setlocal EnableDelayedExpansion
set "str=!str:*:=!"
if defined str set "str=!str:%find%=%repl%!"
echo(!str!
endlocal
)
)
del "%in%"
我所做的更改:
%~1 删除括号。尽管从技术上讲,这不是必需的。像 echo test >"someName.txt".new 这样的东西就可以正常工作。* 来删除行号前缀。ECHO 关闭。 输出。这是通过使用 echo(由于以下任何原因,您仍然可能会看到文件大小发生轻微变化
如果任何行包含空字节,或者任何行的长度 >~8k,脚本将失败。
我讨厌使用批处理编辑文本文件 - 它代码复杂、速度慢,即使是最好的解决方案仍然有很大的局限性。
我建议您使用 JREPL.BAT - a command line regular expression text processing utility . JREPL 是纯脚本(混合批处理/JScript),可以在从 XP 开始的任何 Windows 机器上 native 运行 - 不需要第 3 方 exe 文件或特殊配置。
该工具非常强大,有很多选项。可通过 jrepl/? 从命令行获取完整文档,或通过 jrepl/?? 获取分页帮助。
使用 JREPL 解决您的问题很简单 - 您甚至不需要其他脚本。以下命令将在命令提示符下运行:
jrepl 636170656C6C6133 636170656C6C6134 /f input.txt /o output.txt
如果将命令放在另一个批处理脚本中,请使用 CALL JREPL。
JREPL 比您解决这个简单问题所需的强大得多。但它非常方便,一旦您掌握了实用程序,我想您会发现它有很多用途。特别是如果您学习使用正则表达式以及许多 JREPL 选项。
关于windows - 用于搜索和替换而不跳过空行的批处理脚本, '!' 和 ';'?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41306958/
我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0
我正在尝试测试是否存在表单。我是Rails新手。我的new.html.erb_spec.rb文件的内容是:require'spec_helper'describe"messages/new.html.erb"doit"shouldrendertheform"dorender'/messages/new.html.erb'reponse.shouldhave_form_putting_to(@message)with_submit_buttonendendView本身,new.html.erb,有代码:当我运行rspec时,它失败了:1)messages/new.html.erbshou
我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t
大约一年前,我决定确保每个包含非唯一文本的Flash通知都将从模块中的方法中获取文本。我这样做的最初原因是为了避免一遍又一遍地输入相同的字符串。如果我想更改措辞,我可以在一个地方轻松完成,而且一遍又一遍地重复同一件事而出现拼写错误的可能性也会降低。我最终得到的是这样的:moduleMessagesdefformat_error_messages(errors)errors.map{|attribute,message|"Error:#{attribute.to_s.titleize}#{message}."}enddeferror_message_could_not_find(obje
Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack
我在我的项目中添加了一个系统来重置用户密码并通过电子邮件将密码发送给他,以防他忘记密码。昨天它运行良好(当我实现它时)。当我今天尝试启动服务器时,出现以下错误。=>BootingWEBrick=>Rails3.2.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-CtoshutdownserverExiting/Users/vinayshenoy/.rvm/gems/ruby-1.9.3-p0/gems/actionmailer-3.2.1/lib/action_mailer
在MRIRuby中我可以这样做:deftransferinternal_server=self.init_serverpid=forkdointernal_server.runend#Maketheserverprocessrunindependently.Process.detach(pid)internal_client=self.init_client#Dootherstuffwithconnectingtointernal_server...internal_client.post('somedata')ensure#KillserverProcess.kill('KILL',
在我的应用程序中,我需要能够找到所有数字子字符串,然后扫描每个子字符串,找到第一个匹配范围(例如5到15之间)的子字符串,并将该实例替换为另一个字符串“X”。我的测试字符串s="1foo100bar10gee1"我的初始模式是1个或多个数字的任何字符串,例如,re=Regexp.new(/\d+/)matches=s.scan(re)给出["1","100","10","1"]如果我想用“X”替换第N个匹配项,并且只替换第N个匹配项,我该怎么做?例如,如果我想替换第三个匹配项“10”(匹配项[2]),我不能只说s[matches[2]]="X"因为它做了两次替换“1fooX0barXg
我已经从我的命令行中获得了一切,所以我可以运行rubymyfile并且它可以正常工作。但是当我尝试从sublime中运行它时,我得到了undefinedmethod`require_relative'formain:Object有人知道我的sublime设置中缺少什么吗?我正在使用OSX并安装了rvm。 最佳答案 或者,您可以只使用“require”,它应该可以正常工作。我认为“require_relative”仅适用于ruby1.9+ 关于ruby-主要:Objectwhenrun
我花了三天的时间用头撞墙,试图弄清楚为什么简单的“rake”不能通过我的规范文件。如果您遇到这种情况:任何文件夹路径中都不要有空格!。严重地。事实上,从现在开始,您命名的任何内容都没有空格。这是我的控制台输出:(在/Users/*****/Desktop/LearningRuby/learn_ruby)$rake/Users/*******/Desktop/LearningRuby/learn_ruby/00_hello/hello_spec.rb:116:in`require':cannotloadsuchfile--hello(LoadError) 最佳