多年来我一直遇到这个问题,但不像今天那么频繁。这促使我一劳永逸地问这个问题。
有时(今天对于几乎所有逻辑)我的普通 PHP 代码会因解析错误而失败。有时 PHP 是正确的,但通常不会出错,并且当再次编写完全相同的代码时,它可以正常工作而不会提示。复制和粘贴代码不起作用,必须重新完整输入。
今天,我小心翼翼地按照失败的行准确地输入了每个字符,然后删除了旧的字符,只是为了让脚本正常工作。例如:
1 foreach ($_POST['data_positions'] AS $k => $v) {
2
3 }
在第 1 行抛出一个解析错误。我将代码向下移动到第 2 行并再次写入完全相同的第 1 行(我多次检查每个字符是否相同),然后删除第 2 行,它起作用了。另一个例子:
1 if (is_numeric($k)) {
2
3 }
在第 1 行也失败了。当我重新输入时,它起作用了。再次复制并粘贴该行不起作用。
我 100% 确定代码没有问题,所以这让我相信这是某种编码问题,并且代码的某些部分归因于错误的编码(例如将格式化文本粘贴到电子邮件中)。
我目前正在使用 Sublime Text(但在 Notepad++ 和旧的 Homesite 编辑器中也有相同类型的错误解析错误),在 OS X 上运行 MAMP,但它也发生在我的 Windows 台式机上。
有人知道我能做什么吗?多次编写代码并随机失败是非常烦人的。
编辑(重新打开):
我仍然无法让它正常工作。无论我是将它粘贴到记事本还是从头开始键入一个全新的文件。我已经检查了从数据库到服务器到我的编辑器的所有内容,他们都使用 UFT-8。几乎总是 IF 语句会出错(有时我必须将它们输入 3 或 4 次才能起作用。琐碎的东西,比如 if ($a === 3 || $a === 6) {} 。
编辑(已解决!): 向下滚动查看解决方案,我自己回答了这个问题。
最佳答案
我终于找到了答案。我必须通过反复试验找出我做错了什么。
因此,如果您的代码由于隐藏字符而中断,如果您发现从 UTF-8 切换到 ISO-8859-1 时字符是“”,如果它主要发生在 OSX 和多个编辑器中(两者都是Sublime Text 和 Coda 对我来说)这可能是原因:
在许多操作系统中,当您按下 alt+space 时,您会得到一个不间断空格而不是普通空格。许多编程解析器(例如 PHP、Xcode)在解析该字符时会失败。
要在 Sublime Text 中修复它,您需要编辑 Preferences/Key bindings - User 并添加以下行:
{ "keys": ["alt+space"], "command": "insert_snippet", "args": {"contents": " " } },
请记住,键绑定(bind)文件是一个包含对象的数组,如果您有更多条目,则需要将 , 保留在末尾。如果是最后一个,请将其删除。
如果您需要在任何其他编辑器中修复它,只需 Google 搜索“yourEditor disable alt space”。
编辑:
我也注意到 alt+shift+space 的行为相同,因此我在键绑定(bind)配置中添加了另一行:
{ "keys": ["alt+shift+space"], "command": "insert_snippet", "args": {"contents": " " } },
:)
关于php - Sublime Text/代码无缘无故解析错误,隐藏字符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22221042/
总的来说,我对ruby还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用
我有一个字符串input="maybe(thisis|thatwas)some((nice|ugly)(day|night)|(strange(weather|time)))"Ruby中解析该字符串的最佳方法是什么?我的意思是脚本应该能够像这样构建句子:maybethisissomeuglynightmaybethatwassomenicenightmaybethiswassomestrangetime等等,你明白了......我应该一个字符一个字符地读取字符串并构建一个带有堆栈的状态机来存储括号值以供以后计算,还是有更好的方法?也许为此目的准备了一个开箱即用的库?
我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,
在我的Rails(2.3,Ruby1.8.7)应用程序中,我需要将字符串截断到一定长度。该字符串是unicode,在控制台中运行测试时,例如'א'.length,我意识到返回了双倍长度。我想要一个与编码无关的长度,以便对unicode字符串或latin1编码字符串进行相同的截断。我已经了解了Ruby的大部分unicode资料,但仍然有些一头雾水。应该如何解决这个问题? 最佳答案 Rails有一个返回多字节字符的mb_chars方法。试试unicode_string.mb_chars.slice(0,50)
对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl
大约一年前,我决定确保每个包含非唯一文本的Flash通知都将从模块中的方法中获取文本。我这样做的最初原因是为了避免一遍又一遍地输入相同的字符串。如果我想更改措辞,我可以在一个地方轻松完成,而且一遍又一遍地重复同一件事而出现拼写错误的可能性也会降低。我最终得到的是这样的:moduleMessagesdefformat_error_messages(errors)errors.map{|attribute,message|"Error:#{attribute.to_s.titleize}#{message}."}enddeferror_message_could_not_find(obje
我试图获取一个长度在1到10之间的字符串,并输出将字符串分解为大小为1、2或3的连续子字符串的所有可能方式。例如:输入:123456将整数分割成单个字符,然后继续查找组合。该代码将返回以下所有数组。[1,2,3,4,5,6][12,3,4,5,6][1,23,4,5,6][1,2,34,5,6][1,2,3,45,6][1,2,3,4,56][12,34,5,6][12,3,45,6][12,3,4,56][1,23,45,6][1,2,34,56][1,23,4,56][12,34,56][123,4,5,6][1,234,5,6][1,2,345,6][1,2,3,456][123
如何在buildr项目中使用Ruby?我在很多不同的项目中使用过Ruby、JRuby、Java和Clojure。我目前正在使用我的标准Ruby开发一个模拟应用程序,我想尝试使用Clojure后端(我确实喜欢功能代码)以及JRubygui和测试套件。我还可以看到在未来的不同项目中使用Scala作为后端。我想我要为我的项目尝试一下buildr(http://buildr.apache.org/),但我注意到buildr似乎没有设置为在项目中使用JRuby代码本身!这看起来有点傻,因为该工具旨在统一通用的JVM语言并且是在ruby中构建的。除了将输出的jar包含在一个独特的、仅限ruby
我正在使用的第三方API的文档状态:"[O]urAPIonlyacceptspaddedBase64encodedstrings."什么是“填充的Base64编码字符串”以及如何在Ruby中生成它们。下面的代码是我第一次尝试创建转换为Base64的JSON格式数据。xa=Base64.encode64(a.to_json) 最佳答案 他们说的padding其实就是Base64本身的一部分。它是末尾的“=”和“==”。Base64将3个字节的数据包编码为4个编码字符。所以如果你的输入数据有长度n和n%3=1=>"=="末尾用于填充n%
我主要使用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