//
// 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. Java多线程小结

    简述 Java是支持多线程编程的语言,线程相比于进程更加轻量级,线程共享相同的内存空间,但是拥有独立的栈.减少了进程建立.销毁的资源消耗.jdk1.5后对java的多线程编程提供了更完善的支持,使得j ...

  2. 关于T-SQL重编译那点事,WITH RECOMPILE和OPTION(RECOMPILE)区别仅仅是存储过程级重编译和SQL语句级重编译吗

    本文出处:http://www.cnblogs.com/wy123/p/6262800.html   在考虑重编译T-SQL(或者存储过程)的时候,有两种方式可以实现强制重编译(前提是忽略导致重编译的 ...

  3. 12V继电器开关控制

    案例描述:“灯控项目”中让单片机通过IO口控制继电器,继电器接入GPRS电路板供电电源,从而实现单片机对GPRS电路板的开关控制 电路图 所需元器件:1个五脚继电器,1个NPN三极管,2个电阻,1个二 ...

  4. SQL Server连接Oracle详细步骤

    http://blog.csdn.net/weiwenhp/article/details/8093105 我们知道SQL Server和Oracle其实很多原理都类似.特别是一些常用的SQL语句都是 ...

  5. 3第一周课后练习&#183;阅读计划(2)-使用指针来访问私有数据成员

    /* * Copyright (c) 2015, 计算机科学学院,烟台大学 * All rights reserved. * 文件名:test.cpp * 作 靠:刘畅 * 完成日期:2015年 3 ...

  6. MetaData Lock 杨奇龙 ---MYSQL博客专家

    http://blog.itpub.net/22664653/viewspace-1791608/ http://blog.csdn.net/dba_waterbin/article/details/ ...

  7. Android(java)学习笔记194:ListView编写步骤(重点)

    1.ListView在我们的手机android编写程序中使用是十分广泛的,比如如下图中 短信 和 手机设置 都是ListView的效果: 手机设置:             短信:    2.正因为这 ...

  8. Pivotal Cloud Foundry学习笔记(1)

    PCF是一个PAAS平台 注册PCF账号 https://account.run.pivotal.io/sign-up 安装cf CLI 访问 https://console.run.pivotal. ...

  9. 数据库的CRUD操作

    一:数据库的CRUD操作,C是指create新增,R是指retrieve检索,U是指update更改,D是指delete删除 SQL语句分为3类: 1.DDL指数据定义语言如:create,drop, ...

  10. .net数据传递的格式

    1 Object 返回数据库查询后的单个值 public object LoadBusinessScopeById(int id) { string sql = "select [name] ...