加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

如何使用Haskell访问某些XML数据(使用HaXml)?

发布时间:2020-12-16 07:47:49 所属栏目:百科 来源:网络整理
导读:我希望能够访问 XML文件的数据 ?xml version="1.0"?MY Foo id="1" name="test" Argument name="a" / /Foo Foo id="2" name="test2" Argument name="a" / Argument name="b" / /Foo Other id="2" name="someOther"//MY 我想要,例如用它的Arguments读出每个Foo
我希望能够访问 XML文件的数据
<?xml version="1.0"?>
<MY>
  <Foo id="1" name="test">
    <Argument name="a" />
  </Foo>
  <Foo id="2" name="test2">
    <Argument name="a" />
    <Argument name="b" />
  </Foo>
  <Other id="2" name="someOther"/>
</MY>

我想要,例如用它的Arguments读出每个Foo,我怎么能用Haskell做到这一点? (我想使用HaXml模块)

我不知道从哪里开始.

我找不到haXml的最新文档和示例.

但是有一些HXT的文档可用.
我知道这可能对你的例子来说太过分了,但无论如何.

如果你想使用tagsoup,也许以下答案可能会有所帮助:
xml-tree parser (Haskell) for graph-library
In Haskell how do you extract strings from an XML document?

以下是HXT的文档示例:
http://www.haskell.org/haskellwiki/HXT/Conversion_of_Haskell_data_from/to_XML
http://www.haskell.org/haskellwiki/HXT
http://www.haskell.org/haskellwiki/HXT/Practical
http://en.wikibooks.org/wiki/Haskell/XML

现在代码使用HXT.
(警告我不确定这是否正确)

我按照教程:
http://www.haskell.org/haskellwiki/HXT/Conversion_of_Haskell_data_from/to_XML

你需要你的xml文件为“data.xml”

import Data.Map (Map,fromList,toList)
import Text.XML.HXT.Core


type Foos = Map String [Foo]

data Foo = Foo
     { 
       fooId :: String,fooName :: String,arguments :: [Argument]  
     } 
          deriving (Show,Eq)



data Argument = Argument
      { argName  :: String
      }
           deriving (Show,Eq)

instance XmlPickler Foo where
  xpickle = xpFoo


instance XmlPickler Argument where
  xpickle = xpArgument

-- WHY do we need this?? no clue            
instance XmlPickler Char where
    xpickle = xpPrim

-- this could be wrong
xpFoos :: PU Foos
xpFoos
  = xpWrap (fromList,toList
          ) $
  xpList $
      xpElem "MY" $
      xpickle

xpFoo :: PU Foo
xpFoo
  = xpElem "Foo" $
     xpWrap ( uncurry3 Foo, f -> (fooId f,fooName f,arguments f
                     )  
           ) $         
    xpTriple (xpAttr "id" xpText) 
              (xpAttr "name" xpText)
              (xpList xpickle)


xpArgument :: PU Argument
xpArgument
    = xpElem "Argument" $
       xpWrap (  ((a)) -> Argument a, t -> (argName t)
              ) $
       (xpAttr "name" xpText )


main    :: IO ()
main
     = do
       runX ( xunpickleDocument xpFoos
                                [ withValidate no,withTrace 1,withRemoveWS yes,withPreserveComment no
                                ] "data.xml"
         >>>
             arrIO (  x -> do {print x ; return x}) 
            )
       return ()

结果(您需要xml示例为“data.xml”):

-- (1) getXmlContents
-- (1) readDocument: "data.xml" (mime type: "text/xml" ) will be processed
-- (1) readDocument: "data.xml" processed
fromList [("",[Foo {fooId = "1",fooName = "test",arguments = [Argument {argName = "a"}]},Foo {fooId = "2",fooName = "test2",arguments = [Argument {argName = "a"},Argument     {argName = "b"}]}])]

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读