我一直在尝试以下方法。 我想为 XML 创建一个 XSD,其中某些元素只允许出现一次并且需要有效,并且允许来自其他 namespace 的元素出现在任何地方,并且没有必须用于验证的架构。
应该允许的 XML:
<ns:bookstore>
<ns:books>
<ns:book1 />
<other:magazine1 />
<ns:book2 />
<ns:book3 />
<otherns:newspaper1 />
<ns:book4 />
</ns:books>
</ns:bookstore>
book1,2,3 和 4 只能在 XML 中出现一次并且需要被验证,其他命名空间中的元素然后 ns: 应该被允许而不被验证。为此,我在我的 XSD 中使用 xs:any 和 processContents 松散:
<xs:schema attributeFormDefault="unqualified"
elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema" targetNamespace="ns">
<xs:element name="bookstore">
<xs:complexType>
<xs:sequence >
<xs:element name ="book1" type="xs:string" maxOccurs="1"/>
<xs:element name ="book2" type="xs:string" maxOccurs="1"/>
<xs:element name ="book3" type="xs:string" maxOccurs="1"/>
<xs:element name ="book4" type="xs:string" maxOccurs="1"/>
<xs:any processContents="lax" namespace="##other" minOccurs="0" maxOccurs="unbounded"/>
</xs:sequence>
</xs:complexType>
</xs:element>
在这个解决方案中,其他命名空间中的元素只能出现在序列之后,而不能出现在必填元素之间。理想的解决方案(但我知道它在 XSD 中是不允许的)是更改 xs:all 中的 xs:sequence(但 xs:all 中不允许 xs:any)
我知道有这样的问题,但没有一个答案对我来说是明确的。 有人可以为我提供解决此问题的方法吗?
我还尝试了以下方法:
<xs:schema attributeFormDefault="unqualified"
elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema" targetNamespace="ns">
<xs:element name="bookstore">
<xs:complexType>
<xs:choice maxOccurs="unbounded" >
<xs:element name ="book1" type="xs:string" maxOccurs="1"/>
<xs:element name ="book2" type="xs:string" maxOccurs="1"/>
<xs:element name ="book3" type="xs:string" maxOccurs="1"/>
<xs:element name ="book4" type="xs:string" maxOccurs="1"/>
<xs:any processContents="lax" namespace="##other" minOccurs="0" maxOccurs="unbounded"/>
</xs:choice>
</xs:complexType>
</xs:element>
因为选择的出现是无限的,所以选择中的任何元素都可以在任何位置出现任意多次。但是这里 book1、2、3 和 4 可以出现多次,在我的用例中是不允许的。
有没有人有其他想法可以帮助我?提前致谢!!
P.S.:我的书的类型其实都是complexTypes,而且各不相同,这只是一个简化版的XML。
编辑:
这在我的 XSD 中也是不允许的:
<xs:element name="bookstore">
<xs:complexType>
<xs:sequence >
<xs:element name ="book1" type="xs:string" maxOccurs="1"/>
<xs:any processContents="lax" namespace="##other" minOccurs="0" maxOccurs="unbounded"/>
<xs:element name ="book2" type="xs:string" maxOccurs="1"/>
<xs:any processContents="lax" namespace="##other" minOccurs="0" maxOccurs="unbounded"/>
<xs:element name ="book3" type="xs:string" maxOccurs="1"/>
<xs:element name ="book4" type="xs:string" maxOccurs="1"/>
<xs:any processContents="lax" namespace="##other" minOccurs="0" maxOccurs="unbounded"/>
</xs:sequence>
</xs:complexType>
</xs:element>
最佳答案
在 XSD 1.1 中,您可以通过定义一个开放的内容模型非常轻松地做到这一点:
<xs:complexType ...>
<xs:openContent mode="interleave">
<xs:any namespace=.../>
</xs:openContent>
... regular content model ...
</xs:complexType>
在 1.0 中没有简单的方法;您只需在每个可能的位置放置一个可选的通配符。
关于xml - XSD:允许序列中任意位置来自不同 namespace 的元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25178259/
总的来说,我对ruby还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用
我有一个对象has_many应呈现为xml的子对象。这不是问题。我的问题是我创建了一个Hash包含此数据,就像解析器需要它一样。但是rails自动将整个文件包含在.........我需要摆脱type="array"和我该如何处理?我没有在文档中找到任何内容。 最佳答案 我遇到了同样的问题;这是我的XML:我在用这个:entries.to_xml将散列数据转换为XML,但这会将条目的数据包装到中所以我修改了:entries.to_xml(root:"Contacts")但这仍然将转换后的XML包装在“联系人”中,将我的XML代码修改为
我正在处理旧代码的一部分。beforedoallow_any_instance_of(SportRateManager).toreceive(:create).and_return(true)endRubocop错误如下:Avoidstubbingusing'allow_any_instance_of'我读到了RuboCop::RSpec:AnyInstance我试着像下面那样改变它。由此beforedoallow_any_instance_of(SportRateManager).toreceive(:create).and_return(true)end对此:let(:sport_
给定一个复杂的对象层次结构,幸运的是它不包含循环引用,我如何实现支持各种格式的序列化?我不是来讨论实际实现的。相反,我正在寻找可能会派上用场的设计模式提示。更准确地说:我正在使用Ruby,我想解析XML和JSON数据以构建复杂的对象层次结构。此外,应该可以将该层次结构序列化为JSON、XML和可能的HTML。我可以为此使用Builder模式吗?在任何提到的情况下,我都有某种结构化数据-无论是在内存中还是文本中-我想用它来构建其他东西。我认为将序列化逻辑与实际业务逻辑分开会很好,这样我以后就可以轻松支持多种XML格式。 最佳答案 我最
查看我的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([]),完全相同的对象将用作每个缺失键的默认值。这就是您所拥有的,那是你不想要的。您可以改用
本文主要介绍在使用Selenium进行自动化测试或者任务时,对于使用了iframe的页面,如何定位iframe中的元素文章目录场景描述解决方案具体代码场景描述当我们在使用Selenium进行自动化测试的时候,可能会遇到一些界面或者窗体是使用HTML的iframe标签进行承载的。对于iframe中的标签,如果直接查找是无法找到的,会抛出没有找到元素的异常。比如近在咫尺的例子就是,CSDN的登录窗体就是使用的iframe,大家可以尝试通过F12开发者模式查看到的tag_name,class_name,id或者xpath来定位中的页面元素,会抛出NoSuchElementException异常。解决
我基本上来自Java背景并且努力理解Ruby中的模运算。(5%3)(-5%3)(5%-3)(-5%-3)Java中的上述操作产生,2个-22个-2但在Ruby中,相同的表达式会产生21个-1-2.Ruby在逻辑上有多擅长这个?模块操作在Ruby中是如何实现的?如果将同一个操作定义为一个web服务,两个服务如何匹配逻辑。 最佳答案 在Java中,模运算的结果与被除数的符号相同。在Ruby中,它与除数的符号相同。remainder()在Ruby中与被除数的符号相同。您可能还想引用modulooperation.
我需要一个非常简单的字符串验证器来显示第一个符号与所需格式不对应的位置。我想使用正则表达式,但在这种情况下,我必须找到与表达式相对应的字符串停止的位置,但我找不到可以做到这一点的方法。(这一定是一种相当简单的方法……也许没有?)例如,如果我有正则表达式:/^Q+E+R+$/带字符串:"QQQQEEE2ER"期望的结果应该是7 最佳答案 一个想法:你可以做的是标记你的模式并用可选的嵌套捕获组编写它:^(Q+(E+(R+($)?)?)?)?然后你只需要计算你获得的捕获组的数量就可以知道正则表达式引擎在模式中停止的位置,你可以确定匹配结束
RSpec似乎按顺序匹配方法接收的消息。我不确定如何使以下代码工作:allow(a).toreceive(:f)expect(a).toreceive(:f).with(2)a.f(1)a.f(2)a.f(3)我问的原因是a.f的一些调用是由我的代码的上层控制的,所以我不能对这些方法调用添加期望。 最佳答案 RSpecspy是测试这种情况的一种方式。要监视一个方法,用allowstub,除了方法名称之外没有任何约束,调用该方法,然后expect确切的方法调用。例如:allow(a).toreceive(:f)a.f(2)a.f(1)
我是HanamiWorld的新人。我已经写了这段代码:moduleWeb::Views::HomeclassIndexincludeWeb::ViewincludeHanami::Helpers::HtmlHelperdeftitlehtml.headerdoh1'Testsearchengine',id:'title'hrdiv(id:'test')dolink_to('Home',"/",class:'mnu_orizontal')link_to('About',"/",class:'mnu_orizontal')endendendendend我在模板上调用了title方法。htm