//
// main.swift
// C150805_libxml2r2
// http://git.oschina.net/yao_yu/Swift2015/tree/master/C150805_libxml2r2?dir=1&filepath=C150805_libxml2r2&oid=f80a7498226526b991e7913298c15cd38480aea5&sha=c073af33d0534a10098bb8fcc0706c2fd489dc3f
//
// Created by yao_yu on 15/8/5.
// Copyright © 2015年 yao_yu. All rights reserved.
// import Foundation /* ---------- 扩展 ---------- */ extension NSString{
convenience init?(urlString:String, encoding:NSStringEncoding) {
let url = NSURL(string: urlString)
do {
try self.init(contentsOfURL: url!, encoding: encoding)
} catch {}
}
} extension String {
init?(XMLChar char: UnsafePointer<xmlChar>){
self.init()
if char != nil {
self = String.fromCString(UnsafePointer<CChar>(char))!
}
}
} /* ---------- XML节点 ---------- */ class XMLNode {
var xmlDoc:xmlDocPtr = nil
var xmlNode:xmlNodePtr = nil init(node:xmlNodePtr, document:xmlDocPtr) {
self.xmlNode = node
self.xmlDoc = document
} convenience init(document:xmlDocPtr) {
self.init(node:xmlDocGetRootElement(document), document:document)
} lazy var rawContent:String? = {
return XMLNodeGetContent(self.xmlNode)
// return XMLNodeGetString(self.xmlDoc, xmlNode: self.xmlNode)
}() lazy var children:[XMLNode] = {
return self.xmlNodes2XMLNodes(XMLNodeGetChildren(self.xmlNode))
}() lazy var attributes: [String: String] = {
return XMLNodeGetAttributes(self.xmlNode)
}() subscript(key:String) -> String? {
return attributes[key]
} private func xmlNodes2XMLNodes(nodes:[xmlNodePtr]) -> [XMLNode] {
var xmlNodes = [XMLNode]()
for node in nodes{
xmlNodes.append(XMLNode(node: node, document: xmlDoc))
}
return xmlNodes //下面的代码引发:Command failed due to signal: Abort trap: 6
//return nodes.map{[unowned self] in XMLNode(node:$0, document:self.xmlDoc)}
}
} extension XMLNode {
func xPath(xpath: String) -> [XMLNode] {
return xmlNodes2XMLNodes(XMLFindXPath(self.xmlDoc, xPath: xpath))
}
} /* ---------- libxml2读取工具函数 ---------- */ func XMLNodeGetString(doc:xmlDocPtr, xmlNode:xmlNodePtr) -> String? {
let contentChars = xmlNodeListGetString(doc, xmlNode, )
if contentChars == nil { return nil }
let contentString = String(XMLChar: contentChars)
free(contentChars)
assert(contentString != nil, "XMLNodeGetString: 值转换不成功")
return contentString
} func XMLNodeGetContent(xmlNode:xmlNodePtr) -> String? {
let contentChars = xmlNodeGetContent(xmlNode)
if contentChars == nil { return nil }
let contentString = String(XMLChar: contentChars)
free(contentChars)
assert(contentString != nil, "XMLNodeGetContent: 值转换不成功")
return contentString
} func XMLNodeGetChildren(xmlNode: xmlNodePtr) -> [xmlNodePtr] {
var children = [xmlNodePtr]() for var childNodePointer = xmlNode.memory.children;
childNodePointer != nil;
childNodePointer = childNodePointer.memory.next
{
if xmlNodeIsText(childNodePointer) == {
children.append(childNodePointer)
}
} return children
} func XMLNodeGetAttributes(xmlNode: xmlNodePtr) -> [String: String] {
var result:[String: String] = [String: String]()
for var attribute: xmlAttrPtr = xmlNode.memory.properties;
attribute != nil;
attribute = attribute.memory.next
{
if let key:String = String(XMLChar: attribute.memory.name) {
if let value:String = XMLNodeGetContent(attribute.memory.children) {
result[key] = value
} else {
result[key] = ""
}
} else {
print((">>>>>>>>>>>>>>>>>>>>>>>>错误:", String(XMLChar: attribute.memory.name)))
}
}
return result
} func XMLNodeGetAttribute(xmlNode: xmlNodePtr, key: String) -> String? {
for var attribute: xmlAttrPtr = xmlNode.memory.properties;
attribute != nil;
attribute = attribute.memory.next
{
if key == String(XMLChar: attribute.memory.name) {
return XMLNodeGetContent(attribute.memory.children)
}
}
return nil
} func XMLFindXPath(xmlDoc:xmlDocPtr, xPath: String) -> [xmlNodePtr] {
let xPathContext = xmlXPathNewContext(xmlDoc)
if xPathContext == nil {
return []
} xPathContext.memory.node = nil let xPathObject = xmlXPathEvalExpression(UnsafePointer<xmlChar>(xPath.cStringUsingEncoding(NSUTF8StringEncoding)!), xPathContext)
xmlXPathFreeContext(xPathContext)
if xPathObject == nil {
return []
} let nodeSet = xPathObject.memory.nodesetval
if nodeSet == nil || nodeSet.memory.nodeNr == || nodeSet.memory.nodeTab == nil {
xmlXPathFreeObject(xPathObject)
return []
} var resultNodes = [xmlNodePtr]()
for i in ..< Int(nodeSet.memory.nodeNr) {
resultNodes.append(nodeSet.memory.nodeTab[i])
} xmlXPathFreeObject(xPathObject) return resultNodes
} func XMLReadNSData(data:NSData?, encoding:NSStringEncoding = NSUTF8StringEncoding, isXML:Bool = false) -> xmlDocPtr? {
if let data = data {
let cBuffer = UnsafePointer<CChar>(data.bytes)
let cSize = CInt(data.length)
//
// let cfEncoding = CFStringConvertNSStringEncodingToEncoding(encoding)
// let cfEncodingAsString:CFStringRef = CFStringConvertEncodingToIANACharSetName(cfEncoding)
// let cEncoding:UnsafePointer<CChar> = CFStringGetCStringPtr(cfEncodingAsString, CFStringEncoding(0)) if isXML {
let options = CInt(XML_PARSE_RECOVER.rawValue)
return xmlReadMemory(cBuffer, cSize, nil, nil, options)
} else {
let options = CInt(HTML_PARSE_RECOVER.rawValue | HTML_PARSE_NOWARNING.rawValue | HTML_PARSE_NOERROR.rawValue)
return htmlReadMemory(cBuffer, cSize, nil, nil, options)
}
}
return nil
} let GB18030_2000_Encoding = CFStringConvertEncodingToNSStringEncoding(CFStringEncoding(CFStringEncodings.GB_18030_2000.rawValue)) /* ---------- 测试代码 ---------- */ class CElapseTime {
var startTime:NSDate
var prompt:String
var unsed:Bool = false init(prompt:String) {
self.startTime = NSDate()
self.prompt = prompt
} var newprompt:String {
return "\(prompt)耗时:\(NSDate().timeIntervalSinceDate(startTime))"
}
} func testParseSina() { var sURL:String
var encoding:UInt (sURL,encoding) = ("http://www.baidu.com", NSUTF8StringEncoding)
print("<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<\(sURL)") var timer = CElapseTime(prompt: "读取网页")
//let sContent = NSString(urlString:sURL, encoding: encoding)
var sContent:NSString? = nil
do{
try sContent = NSString(contentsOfFile: "/Volumes/Data/Document/Test/sample.txt", encoding: NSUTF8StringEncoding)
} catch { }
print(timer.newprompt)
let sTimer1 = timer.newprompt
timer = CElapseTime(prompt: "数据解析") if let doc = XMLReadNSData(sContent?.dataUsingEncoding(NSUTF8StringEncoding)){
let rootNode = XMLNode(document: doc)
let findNodes = rootNode.xPath("//div")
for childNode in findNodes {
autoreleasepool{
let _ = (childNode.attributes, childNode.rawContent)
}
// if let content = childNode.rawContent {
// print(content)
// }
}
print(findNodes.count)
}
print(sTimer1)
print(timer.newprompt)
} testParseSina()

在Swift中使用libxml2的更多相关文章

  1. swift 中关于open ,public ,fileprivate,private ,internal,修饰的说明

    关于 swift 中的open ,public ,fileprivate,private, internal的区别 以下按照修饰关键字的访问约束范围 从约束的限定范围大到小的排序进行说明 open,p ...

  2. 阿里巴巴最新开源项目 - [HandyJSON] 在Swift中优雅地处理JSON

    项目名称:HandyJSON 项目地址:https://github.com/alibaba/handyjson 背景 JSON是移动端开发常用的应用层数据交换协议.最常见的场景便是,客户端向服务端发 ...

  3. Swift中的可选链与内存管理(干货系列)

    干货之前:补充一下可选链(optional chain) class A { var p: B? } class B { var p: C? } class C { func cm() -> S ...

  4. 在Swift中实现单例方法

    在写Swift的单例方法之前可以温习一下Objective-C中单例的写法: + (instancetype)sharedSingleton{ static id instance; static d ...

  5. [翻译]理解Swift中的Optional

    原文出处:Understanding Optionals in Swift 苹果新的Swift编程语言带来了一些新的技巧,能使软件开发比以往更方便.更安全.然而,一个很有力的特性Optional,在你 ...

  6. 窥探Swift之使用Web浏览器编译Swift代码以及Swift中的泛型

    有的小伙伴会问:博主,没有Mac怎么学Swift语言呢,我想学Swift,但前提得买个Mac.非也,非也.如果你想了解或者初步学习Swift语言的话,你可以登录这个网站:http://swiftstu ...

  7. swift 中指针的使用UnsafeMutablePointer

    在swift中已经弱化了指针的使用,可以这么使用 let s: NSRange = NSMakeRange(, ) let at = UnsafeMutablePointer<NSRange&g ...

  8. swift 中数据类型那个的转换

    在swift中关于数据类型的转换,如果参数是可选类型? 那么打印或者转换的结果 会带有Optional 字样,,

  9. swift中Range的使用书名

    在swift中Range有两种用法 1.把字符串转换成NSString来使用 //这里是把swift的字符换转换成了nsstring 使用 let str :NSString = text.strin ...

随机推荐

  1. 常用对象API、附加:集合补充

    基本数据类型对象包装类: 为了方便操作基本数据类型值,将其封装成了对象,在对象中定义了属性和行为丰富了该数据的操作. 用于描述该对象的类就称为基本数据类型对象包装类. byte——Byte short ...

  2. eclipse中使用tomcat图解

    配置步骤: 1. tomcat7是绿色软件,解压后即可使用,请大家先将tomcat解压到合适的位置(建议整个路径都是英文路径), 2. 打开eclipse,菜单栏下,File--New--Other. ...

  3. BASH内置变量

    BASH内置变量 ().BASH 作用:bash的完整路径.默认为/bin/bash ().BASH_ENV 作用:仅在非交互模式中适用.在执行shell脚本时,会先检查该变量是否指定了启动 脚本,若 ...

  4. Zookeeper3.4.6部署伪分布集群(Apache)

    1.下载Zookeeper http://mirrors.cnnic.cn/apache/zookeeper/zookeeper-3.4.6/ 2.创建/usr/app/zookeeper目录,并切换 ...

  5. iOS之ASIHttp简单的网络请求实现

    描述: ASIHttpRequest是应用第三方库的方法,利用代码快,减少代码量,提高效率 准备工作: 一.导入第三方库ASIHttpRequest 二.会报很多的错,原因有两个,一个是要导入Xcod ...

  6. 如何设计一个更好的C++ ORM

    2016/11/26 "用C++的方式读写数据库,简直太棒了!" 上一篇相关文章:如何设计一个简单的C++ ORM (旧版代码)

  7. dedeCMS修改文章更新发布时间问题

    今天在dedeCMS系统中,修改或文章时发现,只要提交以后,文章发布时间便是当前时间.但有时候修改文章以后并不想把文章发布时间也更新成修改时间.我希望的是,修改文章不对时间做更改保持文章原有发布时间, ...

  8. Android pulltorefresh引用遇到的一个问题

    今天在使用pulltorefresh插件的时候遇到了一个让人头疼的问题,在Eclipse中导入要用到的library项目,然后新建一个项目引入Library,显示的是引入成功,如图 而且project ...

  9. Java-Android 之出滚动条和卷轴页面

    <?xml version="1.0" encoding="utf-8"?> <HorizontalScrollView xmlns:andr ...

  10. H TML5 之 (1) 初识HTML5

    新特性 HTML5 中的一些有趣的新特性: 用于绘画的 canvas 元素 用于媒介回放的 video 和 audio 元素 对本地离线存储的更好的支持 新的特殊内容元素,比如 article.foo ...