【发布时间】:2017-02-10 06:22:45
【问题描述】:
最近几天,我一直在寻找任何解决方案,以使用 Nokogiri 获取多个节点,以受制于祖先节点中的引用变量。
我需要什么: 实际上我正在收集“Segment”节点的所有“Id”。然后我想用“段”节点收集所有后续的“资源”。为了收集“资源”,我想将“Id”设置为变量。
<CPL>
<SegmL>
<Segment>
<Id>UUID</Id> #UUID as a variable
<Name>name_01</Name>
<SeqL>
<ImageSequence>
<Id>UUID</Id>
<Track>UUID</Track>
<ResourceList>
<Resource> #depending on SegmentId
<A>aaa</A>
<B>bbb</B>
<C>ccc</C>
<D>ddd</D>
</Resource>
</ResourceList>
</ImageSequence>
<AudioSequence>
<Id>UUID</Id>
<Track>UUID</Track>
<ResourceList>
<Resource>
<A>aaa</A>
<B>bbb</B>
<C>ccc</C>
<D>ddd</D>
</Resource>
</ResourceList>
</AudioSequence>
</SequL>
</Segment>
<Segment>
<Id>UUIDa</Id>
<Name>name_02</Name>
<SequL>
<ImageSequence>
<Id>UUID</Id>
<Track>UUID</Track>
<ResourceList>
<Resource>
<A>aaa</A>
<B>bbb</B>
<C>ccc</C>
<D>ddd</D>
</Resource>
</ResourceList>
</ImageSequence>
<AudioSequence>
<Id>UUID</Id>
<Track>UUID</Track>
<ResourceList>
<Resource>
<A>aaa</A>
<B>bbb</B>
<C>ccc</C>
<D>ddd</D>
</Resource>
</ResourceList>
</AudioSequence>
</SequL>
</Segment>
</SegmL>
</CPL>
使用A = Resource.css("A").text.gsub(/\n/,"")收集的所有资源数据
#first each do
cpls.each_with_index do |(cpl_uuid, mycpl), index|
cpl_filename = mycpl
cpl_file = File.open("#{resource_uri}/#{cpl_filename}")
cpl = Nokogiri::XML( cpl_file ).remove_namespaces!
#get UUID for UUID checks
cpl_uuid = cpl.css("Id").first.text.gsub(/\n/,"")
cpl_root_edit_rate = cpl.css("EditRate").first.text.gsub(/\s+/, "\/")
#second each do
cpl.css("Segment").each do |s| # loop segment
cpl_segment_list_uuid = s.css("Id").first.text.gsub(/\n/,"") #uuid of segment list
#third each do
cpl.css("Resource").each do |f| #loop resources
cpl_A = f.css("A").text.gsub(/\n/,"") # uuid of A
cpl_B = f.css("B").text.gsub(/\n/,"") # uuid of B
end #third
end #second
end #first
我的表达式给了我这些存储在数组中的信息:
A = 48000.0
B = 240000.0
C = 0.0
D = 240000.0
Some functions to calculate an average on the resources.
puts all_arry
A = 5.0
B = 5.0
C = 5.0
D = 5.0
A = 5.0
B = 5.0
C = 5.0
D = 5.0
=8 values -> only 4 values existing for the exact loop (2 average values per Segment)
目前所有“SegmentId”正在收集所有“资源”
如何将每个Segment Id作为变量准确分配后续资源?
我曾经使用过这段代码,但是循环是空的,因为在“Segment”的“Id”和每个“Resource”“A”、“B”之间有更多的节点......:
if cpl.at("Segment/Id:contains(\"#{cpl_segment_list_uuid}\")")
cpl.css("Resource").each do |f|
#collecting resources here for each segmet
end
end
所有节点都没有属性、id、类等。
愿你能帮我解决我的问题。首先,我会礼貌地感谢您的支持!
2016 年 10 月 7 日更新
我还使用以下表达式为资源上的“每个执行”运行了代码:
expression = "/SegmetList/Segment[Id>cpl_segment_list_uuid]"
cpl.xpath(expression).each do |f|
它运行“每个都做”,但我没有得到内部节点
cpl.css("Segment:contains(\"#{cpl_segment_list_uuid}\") > Resource").each do |f|
同上
如果使用“if”条件,也会出现同样的问题:
if cpl.at("Segment/Id:contains(\"#{cpl_segment_list_uuid}\")").each do|f|
#some code
end
2016/18/10 更新
实际上我得到了正确数量的资源 (4),但仍然没有为每个段分开。所以每个 Segment 中都有相同的四个资源。
为什么我没有得到所有资源的双倍数,是因为我在“Segment”循环中创建了数组。
这是当前代码:
#first each do
cpls.each_with_index do |(cpl_uuid, mycpl), index|
cpl_filename = mycpl
cpl_file = File.open("#{resource_uri}/#{cpl_filename}")
cpl = Nokogiri::XML( cpl_file ).remove_namespaces!
#get UUID for UUID checks
cpl_uuid = cpl.css("Id").first.text.gsub(/\n/,"")
cpl_root_edit_rate = cpl.css("EditRate").first.text.gsub(/\s+/, "\/")
#second each do
cpl.css("Segment").each do |s| # loop segment
cpl_segment_list_uuid = s.css("Id").first.text.gsub(/\n/,"") #uuid of segment list
array_for_resource_data = Array.new
#third each do
s.css("Resource").each do |f| #loop resources #all resources
s.search('//A | //B').each do |f| #selecting only resources "A" and "B"
cpl_A = f.css("A").text.gsub(/\n/,"") # uuid of A
cpl_B = f.css("B").text.gsub(/\n/,"") # uuid of B
end #third
end #second
end #first
我希望我的更新能给你更多的细节。非常感谢您的帮助和解答!
2016/31/10 更新
段的双重输出的问题是固定的。现在我在段下的每个序列上多了一个循环:
cpl.css("Segment").each do |u|
segment_list_uuid = u.css("Id").first.text.gsub(/\n/,"")
sequence_list_uuid_arr = Array.new
u.xpath("//SequenceList[//*[starts-with(name(),'Sequence')]]").each do |s|
sequence_list_uuid = s.css("TrackId").first.text#.gsub(/\n/,"")
sequence_list_uuid_arr.push(cpl_sequence_list_uuid)
#following some resource nodes
s.css("Resource").each do |f|
asset_uuid = f.css("TrackFileId").text.gsub(/\n/,"")
resource_uuid = f.css("Id").text.gsub(/\n/,"")
edit_rate = f.css("EditRate").text.gsub(/\s+/, "\/")
#some more code
end #resource
end #sequence list
end #segment
现在我想获取每个唯一序列下的所有不同“资源”。我必须列出所有不同的资源并总结一些收集到的值。
有什么方法可以收集同一个“sequence id”下具有不同值(子节点)的每个资源?目前,我不知道任何解决方案....所以没有可以向您展示的代码,可以部分工作。
“资源”循环的each_with_index 不起作用。
您能否提供一些想法或任何方法来帮助我解决我的新问题?
【问题讨论】:
-
见“mcve”。将输入数据和代码减少到演示问题所需的最低限度。除此之外的任何事情都只会使问题变得混乱。更新问题时,将其他内容添加到文本中,如果它最初是它们的话。不要使用“edited”或“updated”类型的标签,因为我们可以知道发生了什么变化。保持问题的可读性和意义比尝试做某种修订标记要重要得多。
标签: css ruby variables nokogiri nodes