我叫 Rithy。
我不知道如何在 xml 中追加新节点或元素之前添加新行。
我的 php:
$dom = new DOMDocument();
$dom->formatOutput = true;
$dom->preserveWhiteSpace = true;
$dom->load($xml_file);
$body = $dom->getElementsByTagName('body')->item(0);
$newelement_seg = $dom->createElement('seg');
$data = $dom->createTextNode(" text 2 ");
$newelement_seg->appendChild($data);
$body->appendChild($newelement_seg);
$dom->save($xml_file);
XML 在追加一个新的 child 之前:
<?xml version="1.0" encoding="UTF-8"?>
<body>
<seg>
text 1
</seg>
</body>
</xml>
追加新 child 后的 XML:
<?xml version="1.0" encoding="UTF-8"?>
<body>
<seg>
text 1
</seg>
<seg>
text 2
</seg>
</body>
</xml>
但我想要:
<?xml version="1.0" encoding="UTF-8"?>
<body>
<seg>
text 1
</seg>
<seg>
text 2
</seg>
</body>
</xml>
<hr/>
提前致谢!
最佳答案
总结给出的答案:
您必须将 formatOutput 设置为 true
你必须将 ignoreWhiteSpace 设置为 false
即:
$dom = new DomDocument();
$dom->formatOutput = true;
$dom->preserveWhiteSpace = false;
$dom->load($myxmlfile);
关于PHP DOM 追加新行的 child ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3155030/
查看我的Ruby代码:h=Hash.new([])h[0]=:word1h[1]=h[1]输出是:Hash={0=>:word1,1=>[:word2,:word3],2=>[:word2,:word3]}我希望有Hash={0=>:word1,1=>[:word2],2=>[:word3]}为什么要附加第二个哈希元素(数组)?如何将新数组元素附加到第三个哈希元素? 最佳答案 如果您提供单个值作为Hash.new的参数(例如Hash.new([]),完全相同的对象将用作每个缺失键的默认值。这就是您所拥有的,那是你不想要的。您可以改用
我有一个正则表达式来获取"*"之间的所有内容:str="Donecsedodiodui.*Nullamiddoloridnibhultriciesvehiculaut*"str.match(/\*(.*)\*/)[1]我希望匹配能够包含换行符。我该怎么做? 最佳答案 您需要使用允许点匹配新行的m选项:Donecsedodiodui.*Nullamiddoloridnibhultriciesvehiculaut*regexstr.match(/\*(.*)\*/m)[1]实例:http://www.rubular.com/r/11u9
我有一个包含许多换行符和空格的字符串。我需要将它拆分成固定长度的子字符串。例如a="Thisissome\nText\nThisissometext"现在我想把它分成长度为17的字符串。所以现在它应该导致["Thisissome\nText","\nThisissometex","t"]评论:我的字符串可能包含任何字符(空格/单词等) 最佳答案 "Thisissome\nText\nThisissometext".scan(/.{1,17}/m)#=>["Thisissome\nText","\nThisissometex","t"
在我看来,以下行为就像assign方法正在按值处理visited,而append方法将其视为引用:classMyClassdefassign(visited)visited+=["A"]enddefappend(visited)visited[]instance.append(visited)visited#=>["A"]有人可以解释这种行为吗?这不是关于Ruby是否支持按引用传递或按值传递的问题,而是关于下面提供的示例,以及为什么两个据称执行相同操作的方法表现出不同行为的问题。 最佳答案 您在第一个方法中重新定义了局部变量。这是一
我在扩展一个在gem中定义并且是ActiveRecord::Base的子类的类时遇到问题。我唯一想扩展这个类的是:有很多:promos然而,扩展倾向于排除原始类。我得到的错误:PGError:ERROR:relation"sites"doesnotexistLINE4:WHEREa.attrelid='"sites"'::regclass^:SELECTa.attname,format_type(a.atttypid,a.atttypmod),d.adsrc,a.attnotnullFROMpg_attributeaLEFTJOINpg_attrdefdONa.attrelid=d.a
我确定这是一个非常简单的问题,但我只是个新手,所以...我有一个模型Game,它has_many:piles。依次堆放has_many:cards。我可以在创建游戏时填充桩和纸牌,所以我目前的代码看起来像:classGameid,"contents"=>"c_type_#{num}")endendendclassPileid,"value"=>num)endendendclassCard现在一切都很好,但是当ActiveRecord知道game_id是外键并且应该引用时传递"game_id"=>id感觉不对家长游戏。但是,如果我将其关闭,外键最终将无法设置。有更好的方法吗?(作为奖励,
我只是想在此字符串的末尾添加一个“/”。执行此操作的最佳方法是什么?>>params[:id]"shirts"我想制作params[:id]=="shirts/"。如何在该字符串的末尾添加/? 最佳答案 最简单的:params[:id]=params[:id]+'/'或params[:id]+='/'莫尔幻想:params[:id]另一种方法:params[:id].concat'/'如果你真的出于某种奇怪的原因坚持使用gsub:params[:id].gsub!/$/,'/' 关于ru
我有一个包含新行的列表,我想将它转换成一个数组,例如JANFEBMARAPRMAY进入["JAN","FEB","MAR","APR","MAY]任何帮助将不胜感激。谢谢这样的东西似乎不起作用(text_file.txt包含上面的月份列表)file=File.new("text_file.txt","r")while(line=file.gets)line.chomplist=line.split(/\n/)puts"#{list}"end 最佳答案 这适用于1.9..不确定是否为空?虽然在1.8中可用%(JANFEBMARAPRM
尝试在rails3中做一个范围。:bookhas_many:chapters我希望scope:long返回超过10章的书籍。如何最好地构建这个范围(不使用计数器缓存)?谢谢! 最佳答案 这应该让你继续:classBookscope:long,joins(:chapters).select('books.id,count(chapters.id)asn_chapters').group('books.id').having('n_chapters>10')end有帮助吗? 关于ruby-o
问题我正在针对各种URL运行一些统计数据。我想找到child数量最集中的顶级元素。我想遵循的方法是识别所有顶级元素,然后确定页面上所有元素的百分比属于它。目标递归地获取给定元素的所有子元素。输入:一个Nokogiri元素输出:Nokogiri元素数组或child总数设置ruby1.9.2Nokogirigem我最终得出的结果(这可行,但不如我在下面选择的答案那么漂亮)getChildCount(elem)children=elem.childrenreturn0unlesschildrenandchildren.count>0child_count=children.countchil