c ++中的Xpath查询(Xpath Query in c++)

我需要在C ++中使用xpath查询来直接从节点<revisions>获取idNumber 。 我尝试了以下内容,它总是返回null 。 请让我知道我做错了什么。

xml文件:

<?xml version="1.0" encoding="UTF-8" ?>

<cw:vessel version="1.07.0075" creationDate="2016-01-26" xmlns:cw="urn:container">
    <!-- saved from url=(0024)http://www.systemsoftsol.com/ -->
    <Exchanger>
        <revisions>
            <revision>
               <idNumber>1401889476</idNumber>
               <revNumber>0</revNumber>
               <revDate>2014-06-04</revDate>
               <operator>devin</operator>
               <notes>read me</notes>
            </revision>
        </revisions>
  </Exchanger>
</cw:vessel>

我的代码到目前为止:

void GetProperties()
{
    HRESULT                         hr = NOERROR;
    CComPtr<::IXMLDOMDocument3>     m_pxmlDomDocument = NULL;
    CComPtr<::IXMLDOMNode>          pNode = NULL;
    IXMLDOMNodeList*                pChildlist = NULL;
    VARIANT_BOOL                    vLoadBool = VARIANT_FALSE;
    hr = m_pxmlDomDocument.CoCreateInstance(__uuidof(DOMDocument60));
    hr = m_pxmlDomDocument->setProperty(BSTR(L"SelectionLanguage"), (CComVariant)L"XPath");
    hr = m_pxmlDomDocument->setProperty((CComBSTR)"MaxElementDepth", (CComVariant)INT_MAX);
    if (FAILED(hr))
    {
        hr = ERROR_XML_PARSE_ERROR;
    }
    CComVariant varXmlFileName(_T("xmlfileinput"));
    m_pxmlDomDocument->load(varXmlFileName, &vLoadBool);
    hr = m_pxmlDomDocument->get_documentElement(&pDocRoot);
    hr = pDocRoot->selectSingleNode(_T("//Exchanger"), &pNode);
    pNode->get_childNodes(&pChildlist);
    long size;
    hr = pChildlist->get_length(&size);
    for (int i = 0; i < size; i++)
    {
        CComPtr<::IXMLDOMNode> referNode;
        hr = pChildlist->get_item(i, &referNode);
        if (referNode != NULL)
        {
            CString         csXPathQuery;
            csXPathQuery.Append(_T("/idNumber"));// i need this from above xml
            CComBSTR                    csBstrQuery(csXPathQuery);
            CComPtr<::IXMLDOMNode> pPa;
            hr = referNode->selectSingleNode(csBstrQuery.m_str, &pPa);
        }
    }
}   

selectSingleNode()在上面的代码片段中返回null ,即使我在xml文件中仍然有idNumber


I need a xpath query in C++ to get the idNumber directly from the node <revisions>. I tried the following and it always returns null. Please let me know what I am doing wrong.

xml File:

<?xml version="1.0" encoding="UTF-8" ?>

<cw:vessel version="1.07.0075" creationDate="2016-01-26" xmlns:cw="urn:container">
    <!-- saved from url=(0024)http://www.systemsoftsol.com/ -->
    <Exchanger>
        <revisions>
            <revision>
               <idNumber>1401889476</idNumber>
               <revNumber>0</revNumber>
               <revDate>2014-06-04</revDate>
               <operator>devin</operator>
               <notes>read me</notes>
            </revision>
        </revisions>
  </Exchanger>
</cw:vessel>

My code so far:

void GetProperties()
{
    HRESULT                         hr = NOERROR;
    CComPtr<::IXMLDOMDocument3>     m_pxmlDomDocument = NULL;
    CComPtr<::IXMLDOMNode>          pNode = NULL;
    IXMLDOMNodeList*                pChildlist = NULL;
    VARIANT_BOOL                    vLoadBool = VARIANT_FALSE;
    hr = m_pxmlDomDocument.CoCreateInstance(__uuidof(DOMDocument60));
    hr = m_pxmlDomDocument->setProperty(BSTR(L"SelectionLanguage"), (CComVariant)L"XPath");
    hr = m_pxmlDomDocument->setProperty((CComBSTR)"MaxElementDepth", (CComVariant)INT_MAX);
    if (FAILED(hr))
    {
        hr = ERROR_XML_PARSE_ERROR;
    }
    CComVariant varXmlFileName(_T("xmlfileinput"));
    m_pxmlDomDocument->load(varXmlFileName, &vLoadBool);
    hr = m_pxmlDomDocument->get_documentElement(&pDocRoot);
    hr = pDocRoot->selectSingleNode(_T("//Exchanger"), &pNode);
    pNode->get_childNodes(&pChildlist);
    long size;
    hr = pChildlist->get_length(&size);
    for (int i = 0; i < size; i++)
    {
        CComPtr<::IXMLDOMNode> referNode;
        hr = pChildlist->get_item(i, &referNode);
        if (referNode != NULL)
        {
            CString         csXPathQuery;
            csXPathQuery.Append(_T("/idNumber"));// i need this from above xml
            CComBSTR                    csBstrQuery(csXPathQuery);
            CComPtr<::IXMLDOMNode> pPa;
            hr = referNode->selectSingleNode(csBstrQuery.m_str, &pPa);
        }
    }
}   

selectSingleNode() returns null in the above piece of code even though I still have the idNumber in the xml file.


原文:https://stackoverflow.com/questions/35580202
2023-11-10 14:11

满意答案

我刚写了一些可能有帮助的代码。 这还没有使用任何scala DSL用于硒。

class EnrollTest extends FlatSpec with ShouldMatchers{

  var driver = new FirefoxDriver
  driver.manage.timeouts.implicitlyWait(10, TimeUnit.SECONDS)


  val beginnersPage = BeginnersPage.open(driver)

  "Enroll button" should "open enroll page" in {
    try {
      val timeOfFirstCourse = beginnersPage.enrollForTheFirstCourse
      val enrollPage = new EnrollPage(driver)

      enrollPage.shouldBeOpen
      enrollPage.courseDetails should include(timeOfFirstCourse)
    }
    finally{
      driver.quit
    }
  }

}

和页面类:

object BeginnersPage{
  val url = "http://"+System.getProperty("testUrl", "www.2ndlanguage.co.uk")+"/beginners.action"

  def open(driver : WebDriver) : BeginnersPage = {
    driver.get(url)
    new BeginnersPage(driver)
  }

}

class BeginnersPage(driver : WebDriver){
  private var firstEnrollButton: WebElement = driver.findElement(By.xpath("//div[@class='newPriceBoxRight']/a/div"))
  private var firstCourseTime: WebElement = driver.findElement(By.xpath("//div[@class='newPriceBoxLeft']//span[@id='time']"))

  def enrollForTheFirstCourse : String = {
    val time = firstCourseTime.getText
    firstEnrollButton.click
    time
  }
}

class EnrollPage(driver : WebDriver){
  def isOpen = driver.getCurrentUrl startsWith "http://www.2ndlanguage.co.uk/offer.action"
  def courseDetails = driver.findElement(By.id("courseDetailsTextArea")).getText
}

I just wrote some code which might be of help. This isn't using any scala DSL for selenium yet.

class EnrollTest extends FlatSpec with ShouldMatchers{

  var driver = new FirefoxDriver
  driver.manage.timeouts.implicitlyWait(10, TimeUnit.SECONDS)


  val beginnersPage = BeginnersPage.open(driver)

  "Enroll button" should "open enroll page" in {
    try {
      val timeOfFirstCourse = beginnersPage.enrollForTheFirstCourse
      val enrollPage = new EnrollPage(driver)

      enrollPage.shouldBeOpen
      enrollPage.courseDetails should include(timeOfFirstCourse)
    }
    finally{
      driver.quit
    }
  }

}

And the page classes:

object BeginnersPage{
  val url = "http://"+System.getProperty("testUrl", "www.2ndlanguage.co.uk")+"/beginners.action"

  def open(driver : WebDriver) : BeginnersPage = {
    driver.get(url)
    new BeginnersPage(driver)
  }

}

class BeginnersPage(driver : WebDriver){
  private var firstEnrollButton: WebElement = driver.findElement(By.xpath("//div[@class='newPriceBoxRight']/a/div"))
  private var firstCourseTime: WebElement = driver.findElement(By.xpath("//div[@class='newPriceBoxLeft']//span[@id='time']"))

  def enrollForTheFirstCourse : String = {
    val time = firstCourseTime.getText
    firstEnrollButton.click
    time
  }
}

class EnrollPage(driver : WebDriver){
  def isOpen = driver.getCurrentUrl startsWith "http://www.2ndlanguage.co.uk/offer.action"
  def courseDetails = driver.findElement(By.id("courseDetailsTextArea")).getText
}

相关问答

更多

在Scala Specs中,什么是“必须”功能?(In Scala Specs, what is the “must” function?)

至少在Specs2.0中,您会在org.specs2.matcher.MustExpectable中找到must的定义 /** * This kind of expectable can be followed by the verb must to apply a matcher: * * `1 must beEqualTo(1)` * * For convenience, several mustMatcher methods have also been defined as ...

Scala specs2与“aka”匹配(Scala specs2 matchers with “aka”)

我不认为有适用于所有匹配器的解决方案。 在这种情况下,您可以重复使用aka机器 def contain(expected: Expectable[String]): Matcher[String] = new Matcher[String] { def apply[S <: String](e: Expectable[S]): MatchResult[S] = result(e.value.contains(expected.value), s" ${e.value} co...

ScalaTest和Scala Specs单元测试框架有什么区别?(What’s the difference between ScalaTest and Scala Specs unit test frameworks?)

Specs和ScalaTest都是用户愉快的好工具,但是它们在几个方面有所不同。 您可能想要选择一个作为Scala中的主要测试工具,但不需要放弃另一个,因为您可以使用两者。 例如,如果您喜欢ScalaTest的FeatureSpec语法和规范的Mockito语法,则可以将两个jar文件放在类路径中并同时使用两者。 在这里,我将尝试捕捉我在ScalaTest和ScalaTest之间注意到的主要设计理念差异。 这些工具之间的主要哲学差异可能是规范是为行为驱动开发(BDD)设计的,而ScalaTest则...

规格2:使用Hamcrest匹配器(Specs2: Use a Hamcrest matcher)

您需要为此添加一个隐式转换: import org.hamcrest._ import org.specs2.matcher.MustMatchers._ implicit def asSpecs2Matcher[T](hamcrest: org.hamcrest.TypeSafeMatcher[T]): org.specs2.matcher.Matcher[T] = { def koMessage(a: Any) = { val description = new ...

剧本中的Specs2测试让我“找不到类型为org.specs2.main.CommandLineAsResult的证据参数的隐式值(Specs2 test within plays gives me "could not find implicit value for evidence parameter of type org.specs2.main.CommandLineAsResult)

我认为你使用的是错误的WithApplication导入。 使用这一个: import play.api.test.WithApplication I think you are using the wrong WithApplication import. Use this one: import play.api.test.WithApplication

如何在eclipse中运行scala specs 2(How to run scala specs 2 in eclipse)

目前,您可以使用一些小技巧。 如果您按照以下方式注释您的Specs2类: @RunWith(classOf[JUnitRunner]) 对于旧版本的specs2,这应该是: @RunWith(classOf[JUnitSuiteRunner]) Scala IDE可以通过弹出式菜单通过JUnit运行器运行它(详情请参阅此处 )。 我正在为Scala IDE开发一个Specs2插件(不过,很遗憾,我还没有真正找到时间,但它仍然在我的列表中)。 它有一个适用于以前版本Scala IDE的工作版本,...

验收风格测试有利于使用Specs2进行单元样式测试?(Acceptance style testing in favour of unit style testing with Specs2?)

没有技术上的原因你不能使用“Acceptance”样式来编写单元测试,反之使用“Unit”样式来编写验收测试(因为你可以使用带代码折叠的编辑器来显示文本,或者你可以使用plan参数执行规范并获取规范的全文而无需执行示例)。 您需要注意的两个“技术”事项: “unit”规范使用变量来注册示例,因此如果您尝试使用不同的线程构建此类规范,则会遇到并发问题 “接受”规范使用示例的最后一个值作为结果。 所以,默认情况下,当你想在一个例子中每行写一个期望时,它就不太方便了。 要解决这个问题,您需要混合使用Th...

硒,规格和斯卡拉(Selenium, specs and scala)

我刚写了一些可能有帮助的代码。 这还没有使用任何scala DSL用于硒。 class EnrollTest extends FlatSpec with ShouldMatchers{ var driver = new FirefoxDriver driver.manage.timeouts.implicitlyWait(10, TimeUnit.SECONDS) val beginnersPage = BeginnersPage.open(driver) "Enroll ...

规格2,顺序与否(Specs2, sequential or not)

由于您使用模拟,最简单的方法是每个示例创建一个。 像这样,所有示例都是独立的,可以同时执行。 Since you are using a mock the easiest thing to do is to create one per example. Like this all the examples are independent and can be executed concurrently.

相关文章

更多

《C/C++图像处理编程》扫描版[PDF]

中文名: C/C++图像处理编程 作者: 陆宗骐 图书分类: 网络 资源格式: PD ...

谁给推荐一个C++的JSON库

现在的一个项目,有JAVA的系统,有C++的服务器端,java端和C++服务器通信使用JSON格式,之 ...

C++ Hadoop实战备忘

前言:Hadoop用于解决大数据处理问题。看到这么火,咱也来凑把热闹,瞧瞧到底是什么神奇的技术。 实战 ...

《轻松学C++编程》扫描版[PDF]

中文名: 轻松学C++编程 作者: 胡超 闫玉宝等 图书分类: 软件 资源格式 ...

java server怎样和c++ client实现SSL通信??

java keytool生成的证书是CRT等格式的,这种格式是2进制编码的,而C++用的证书格式是pe ...

《上海交大C++面向对象》[RMVB]

中文名: 上海交大C++面向对象 别名: C++面向对象 资源格式: RMVB 发行 ...

solr delete query

Solr1.4 Both delete by id and delete by query can b ...

solr delete query

Solr1.4 Both delete by id and delete by query can b ...

《数据结构(C++版)(第2版)》扫描版[PDF]

中文名: 数据结构(C++版)(第2版) 作者: 王红梅 胡明 王涛 图书分类 ...

《新版 Visual C++全能速查宝典》扫描版[PDF]

中文名: 新版 Visual C++全能速查宝典 作者: 曹飞飞 赵永发 朱晓 ...

最新问答

更多

您如何使用git diff文件,并将其应用于同一存储库的副本的本地分支?(How do you take a git diff file, and apply it to a local branch that is a copy of the same repository?)

将diff文件复制到存储库的根目录,然后执行以下操作: git apply yourcoworkers.diff 有关apply命令的更多信息, apply 见其手册页 。 顺便说一下:一个更好的方法是通过文件交换整个提交文件是发送者上的命令git format-patch ,然后在接收器上加上git am ,因为它也传送作者信息和提交信息。 如果修补程序应用程序失败,并且生成diff的提交实际上在您的备份中,则可以使用尝试在更改中合并的apply程序的-3选项。 它还适用于Unix管道,如下

将长浮点值剪切为2个小数点并复制到字符数组(Cut Long Float Value to 2 decimal points and copy to Character Array)

尝试将第二行更改为snprintf(buf1, sizeof buf1, "%.2f", balance1); 。 另外,为什么要声明用该特定表达式分配缓冲区的存储量? EDIT @LưuVĩnhPhúc在下面的评论中提到我的原始答案中的格式说明符将舍入而不是截断,因此根据如何在不使用C舍入的情况下截断小数,您可以执行以下操作: float balance = 200.56866; int tmp = balance1 * 100; float balance1 = tmp / 100.0; c

OctoberCMS侧边栏不呈现(OctoberCMS Sidebar not rendering)

这是简单的解决方案 在你需要写的控制器中 BackendMenu::setContext('Archetypics.Team', 'website', 'team'); 请参阅https://octobercms.com/docs/backend/controllers-views-ajax#navigation-context BackendMenu::setContext('Author.Plugin name', 'Menu code', 'Sub menu code'); 你需要在r

页面加载后对象是否有资格进行垃圾回收?(Are objects eligible for garbage collection after the page loads?)

每当发出请求时ASP都会创建一个新的Page对象,并且一旦它将响应发送回用户就不会保留对该Page对象的引用,因此只要你找不到某种方法来保持生命自己引用该Page对象后,一旦发送响应, Page和只能通过该页面访问的所有对象才有资格进行垃圾回收。 ASP creates a new Page object whenever a request is made, and it does not hold onto the reference to that Page object once it

codeigniter中的语言不能按预期工作(language in codeigniter doesn' t work as expected)

要在生产服务器中调试这个,你可以临时放 error_reporting(E_ALL); 并查看有哪些其他错误阻止正确的重定向。 您还应该检查生产服务器发送的响应标头。 它是否具有“缓存”,是否需要重新验证标头等 to debug this in production server, you can temporary put error_reporting(E_ALL); and see what other errors are there that prevents the proper

在计算机拍照在哪里进入

打开娥的电脑.在下面找到视频设备点击进去就可以了...

使用cin.get()从c ++中的输入流中丢弃不需要的字符(Using cin.get() to discard unwanted characters from the input stream in c++)

你是对的。 第一次输入后,换行符将保留在输入缓冲区中。 第一次读取后尝试插入: cin.ignore(); // to ignore the newline character 或者更好的是: //discards all input in the standard input stream up to and including the first newline. cin.ignore(numeric_limits::max(), '\n'); 您必须为#inc

No for循环将在for循环中运行。(No for loop will run inside for loop. Testing for primes)

for (int k = 0; k > 10; k++) { System.out.println(k); } k不大于10,所以循环将永远不会执行。 我想要什么是k<10 ,不是吗? for (int k = 0; k < 10; k++) { System.out.println(k); } for (int k = 0; k > 10; k++) { System.out.println(k); } k is not greater than 10, so loop

单页应用程序:页面重新加载(Single Page Application: page reload)

优点是不注销会避免惹恼用户,以至于他们会想要杀死你:-)。 说真的,如果每次刷新页面时应用程序都会将我注销(或者在新选项卡中打开一个链接),我再也不会使用该应用程序了。 好吧,不要这样做。 确保身份验证令牌存储在刷新后的某个位置,即不在某些JS变量中,而是存储在cookie或本地存储中。 The advantage is that not logging off will avoid pissing off your users so much that they'll want to kill

在循环中选择具有相似模式的列名称(Selecting Column Name With Similar Pattern in a Loop)

EXECUTE IMMEDIATE 'SELECT '||field_val_temp ||' FROM tableb WHERE function_id = :func_val AND rec_key = :rec_key' INTO field_val USING 'STDCUSAC' , yu.rec_key; 和, EXECUTE IMMEDIATE 'UPDATE tablec SET field_val_'||i||' = :field_val' USI