我有一个 Windows CMD 脚本,它正在我们 Wintel Assets 中的许多机器上处理文件,并将它们提供给我们的 SFTP 网关。
作业采用多个参数来确定要处理给定目录中的哪些文件。 当作业执行时,它会扫描目录以查找与正则表达式 %FM_PREF%(Filemase 前缀)和 %FM_SUFF%(Filemask 后缀)匹配的文件,并继续将“最旧”的文件名存储为变量(“%FILE_IN_PROCESS ")
这是通过以下方式实现的:
for /F "usebackq delims=" %%f in (`dir /b /o:-d "%FM_PREF%"*."%FM_SUFF%"`) do set FILE_IN_PROCESS=%%f
然后它通过检查以下的 %ERRORLEVEL% 来检查它是否可以获得文件的独占锁:
echo.N|copy /-y NUL "%FILE_IN_PROCESS%" 1>NUL 2>NUL
我刚刚遇到的问题是,我被要求使用这个过程来处理打印服务器上的文件,而正在创建的文件的文件名中包含空格。
这不是什么大问题,因为我可以通过这样做来重命名“%FILE_IN_PROCESS%”:
echo %FILE_IN_PROCESS% | find " "
if %ERRORLEVEL% EQU 0 cmd /e:on /v:on /c "for %f in ("%FILE_IN_PROCESS%") do (set "n=%~nxf" & set "n=!n: =_!" & ren "%~ff" "!n!" )"
挑战在于我想要 !n! 的值返回到父进程,以便我可以将 %FILE_IN_PROCESS% 变量重置为新文件名(已将空格转换为下划线)
我被困住了...作为 20 多年的 Unix 系统管理员,Windows/DOS/CMD 文件不是我的专业领域。
是否有可能将一个值返回到生成“cmd/e ......”命令的原始作业,或者我是否必须编写一个讨厌的解决方法,比如在磁盘上创建一个临时文件并将其读回 %FILE_IN_PROCESS% 变量?
建议感谢 ???
由@jeb 回答 我创建了一个名为“dave.cmd”的脚本的简化版本
setlocal EnableDelayedExpansion
set FM_PREF=TNO_A4
set FM_SUFF=tno
for /F "usebackq delims=" %%f in (`dir /b /o:-d "%FM_PREF%"*."%FM_SUFF%"`) do set FILE_IN_PROCESS=%%f
echo.
echo pre FILE_IN_PROCESS=%FILE_IN_PROCESS%
echo.
echo "%FILE_IN_PROCESS%" | find " " 1> NUL 2>NUL
if %ERRORLEVEL% EQU 0 (
set "newName=!FILE_IN_PROCESS: =_!"
ren "!FILE_IN_PROCESS!" "!newName!"
)
set FILE_IN_PROCESS=%newName%
echo post FILE_IN_PROCESS=%FILE_IN_PROCESS%
然后证明它有效:
C:\temp\space>date /t > "TNO_A4 a b c dave.tno"
C:\temp\space>.\dave.cmd
pre FILE_IN_PROCESS=TNO_A4 a b c dave.tno
post FILE_IN_PROCESS=TNO_A4_a_b_c_dave.tno
C:\temp\space>
最佳答案
我完全不明白你为什么需要它?
您不需要启动子 cmd,您可以在同一个批处理上下文中执行。
setlocal EnableDelayedExpansion
...
if %ERRORLEVEL% EQU 0 (
set "newName=!FILE_IN_PROCESS: =_!"
ren "!FILE_IN_PROCESS!" "!newName!"
)
但我想知道您是否可以只使用未修改的名称?
关于Windows:从 CMD 返回值以存储为变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33301673/
我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返
我正在查看instance_variable_set的文档并看到给出的示例代码是这样做的:obj.instance_variable_set(:@instnc_var,"valuefortheinstancevariable")然后允许您在类的任何实例方法中以@instnc_var的形式访问该变量。我想知道为什么在@instnc_var之前需要一个冒号:。冒号有什么作用? 最佳答案 我的第一直觉是告诉你不要使用instance_variable_set除非你真的知道你用它做什么。它本质上是一种元编程工具或绕过实例变量可见性的黑客攻击
我正在编写一个gem,我必须在其中fork两个启动两个webrick服务器的进程。我想通过基类的类方法启动这个服务器,因为应该只有这两个服务器在运行,而不是多个。在运行时,我想调用这两个服务器上的一些方法来更改变量。我的问题是,我无法通过基类的类方法访问fork的实例变量。此外,我不能在我的基类中使用线程,因为在幕后我正在使用另一个不是线程安全的库。所以我必须将每个服务器派生到它自己的进程。我用类变量试过了,比如@@server。但是当我试图通过基类访问这个变量时,它是nil。我读到在Ruby中不可能在分支之间共享类变量,对吗?那么,还有其他解决办法吗?我考虑过使用单例,但我不确定这是
我是一个Rails初学者,但我想从我的RailsView(html.haml文件)中查看Ruby变量的内容。我试图在ruby中打印出变量(认为它会在终端中出现),但没有得到任何结果。有什么建议吗?我知道Rails调试器,但更喜欢使用inspect来打印我的变量。 最佳答案 您可以在View中使用puts方法将信息输出到服务器控制台。您应该能够在View中的任何位置使用Haml执行以下操作:-puts@my_variable.inspect 关于ruby-on-rails-如何在我的R
我有一个包含多个键的散列和一个字符串,该字符串不包含散列中的任何键或包含一个键。h={"k1"=>"v1","k2"=>"v2","k3"=>"v3"}s="thisisanexamplestringthatmightoccurwithakeysomewhereinthestringk1(withspecialcharacterslike(^&*$#@!^&&*))"检查s是否包含h中的任何键的最佳方法是什么,如果包含,则返回它包含的键的值?例如,对于上面的h和s的例子,输出应该是v1。编辑:只有字符串是用户定义的。哈希将始终相同。 最佳答案
这似乎非常适得其反,因为太多的gem会在window上破裂。我一直在处理很多mysql和ruby-mysqlgem问题(gem本身发生段错误,一个名为UnixSocket的类显然在Windows机器上不能正常工作,等等)。我只是在浪费时间吗?我应该转向不同的脚本语言吗? 最佳答案 我在Windows上使用Ruby的经验很少,但是当我开始使用Ruby时,我是在Windows上,我的总体印象是它不是Windows原生系统。因此,在主要使用Windows多年之后,开始使用Ruby促使我切换回原来的系统Unix,这次是Linux。Rub
所以我开始关注ruby,很多东西看起来不错,但我对隐式return语句很反感。我理解默认情况下让所有内容返回self或nil但不是语句的最后一个值。对我来说,它看起来非常脆弱(尤其是)如果你正在使用一个不打算返回某些东西的方法(尤其是一个改变状态/破坏性方法的函数!),其他人可能最终依赖于一个返回对方法的目的并不重要,并且有很大的改变机会。隐式返回有什么意义?有没有办法让事情变得更简单?总是有返回以防止隐含返回被认为是好的做法吗?我是不是太担心这个了?附言当人们想要从方法中返回特定的东西时,他们是否经常使用隐式返回,这不是让你组中的其他人更容易破坏彼此的代码吗?当然,记录一切并给出
我收到格式为的回复#我需要将其转换为哈希值(针对活跃商家)。目前我正在遍历变量并执行此操作:response.instance_variables.eachdo|r|my_hash.merge!(r.to_s.delete("@").intern=>response.instance_eval(r.to_s.delete("@")))end这有效,它将生成{:first="charlie",:last=>"kelly"},但它似乎有点hacky和不稳定。有更好的方法吗?编辑:我刚刚意识到我可以使用instance_variable_get作为该等式的第二部分,但这仍然是主要问题。