Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tadija/AEXML
Swift minion for simple and lightweight XML parsing
https://github.com/tadija/AEXML
Last synced: 4 days ago
JSON representation
Swift minion for simple and lightweight XML parsing
- Host: GitHub
- URL: https://github.com/tadija/AEXML
- Owner: tadija
- License: mit
- Created: 2014-10-16T14:21:05.000Z (about 10 years ago)
- Default Branch: master
- Last Pushed: 2024-01-16T21:47:56.000Z (11 months ago)
- Last Synced: 2024-10-29T20:33:36.813Z (about 1 month ago)
- Language: Swift
- Homepage:
- Size: 338 KB
- Stars: 1,012
- Watchers: 39
- Forks: 200
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-ios - AEXML - Simple and lightweight XML parser written in Swift. (Parsing / XML & HTML)
- awesome-swift - AEXML - xml wrapper. (Libs / Data Management)
- awesome-swift - AEXML - Simple and lightweight XML parser for iOS written in Swift. (JSON/XML Manipulation)
- awesome-swift - AEXML - xml wrapper. (Libs / Data Management)
- fucking-awesome-swift - AEXML - xml wrapper. (Libs / Data Management)
- awesome-ios-star - AEXML - Simple and lightweight XML parser written in Swift. (Parsing / XML & HTML)
- awesome-swift-cn - AEXML - xml wrapper. (Libs / Data Management)
- awesome-swift - AEXML - Swift minion for simple and lightweight XML parsing ` 📝 9 months ago` (Data Management [🔝](#readme))
README
[![Swift 5.3](https://img.shields.io/badge/Swift-5.3-orange.svg?style=flat)](https://swift.org)
[![Platforms iOS | watchOS | tvOS | macOS](https://img.shields.io/badge/Platforms-iOS%20%7C%20watchOS%20%7C%20tvOS%20%7C%20macOS-lightgray.svg?style=flat)](http://www.apple.com)
[![CocoaPods](https://img.shields.io/cocoapods/v/AEXML.svg?style=flat)](https://cocoapods.org/pods/AEXML)
[![Carthage](https://img.shields.io/badge/Carthage-compatible-brightgreen.svg?style=flat)](https://github.com/Carthage/Carthage)
[![Swift Package Manager](https://img.shields.io/badge/SPM-compatible-brightgreen.svg)](https://github.com/apple/swift-package-manager)
[![License MIT](https://img.shields.io/badge/License-MIT-lightgrey.svg?style=flat)](https://github.com/tadija/AEXML/blob/master/LICENSE)# AEXML
**Swift minion for simple and lightweight XML parsing**
> I made this for personal use, but feel free to use it or contribute.
> For more examples check out [Sources](Sources) and [Tests](Tests).## Index
- [Intro](#intro)
- [Features](#features)
- [Usage](#usage)
- [Read XML](#read-xml)
- [Write XML](#write-xml)
- [Installation](#installation)
- [License](#license)## Intro
This is not a robust full featured XML parser, but rather simple, lightweight and easy to use utility for casual XML handling.
## Features
- **Read XML** data
- **Write XML** string
- Covered with [unit tests](https://github.com/tadija/AEXML/blob/master/Tests/AEXMLTests.swift)
- Covered with inline docs## Usage
### Read XML
Let's say this is some XML string you picked up somewhere and made a variable `data: Data` from that.```xml
Tinna
Rose
Caesar
Villy
Spot
Betty
Kika
```
This is how you can use **AEXML** for working with this data:
(for even more examples, look at the unit tests code included in project)```swift
guard let
let xmlPath = Bundle.main.path(forResource: "example", ofType: "xml"),
let data = try? Data(contentsOf: URL(fileURLWithPath: xmlPath))
else { return }do {
let xmlDoc = try AEXMLDocument(xml: data, options: options)
// prints the same XML structure as original
print(xmlDoc.xml)
// prints cats, dogs
for child in xmlDoc.root.children {
print(child.name)
}
// prints Optional("Tinna") (first element)
print(xmlDoc.root["cats"]["cat"].value)
// prints Tinna (first element)
print(xmlDoc.root["cats"]["cat"].string)
// prints Optional("Kika") (last element)
print(xmlDoc.root["dogs"]["dog"].last?.value)
// prints Betty (3rd element)
print(xmlDoc.root["dogs"].children[2].string)
// prints Tinna, Rose, Caesar
if let cats = xmlDoc.root["cats"]["cat"].all {
for cat in cats {
if let name = cat.value {
print(name)
}
}
}
// prints Villy, Spot
for dog in xmlDoc.root["dogs"]["dog"].all! {
if let color = dog.attributes["color"] {
if color == "white" {
print(dog.string)
}
}
}
// prints Tinna
if let cats = xmlDoc.root["cats"]["cat"].all(withValue: "Tinna") {
for cat in cats {
print(cat.string)
}
}
// prints Caesar
if let cats = xmlDoc.root["cats"]["cat"].all(withAttributes: ["breed" : "Domestic", "color" : "yellow"]) {
for cat in cats {
print(cat.string)
}
}
// prints 4
print(xmlDoc.root["cats"]["cat"].count)
// prints Siberian
print(xmlDoc.root["cats"]["cat"].attributes["breed"]!)
// prints Tinna
print(xmlDoc.root["cats"]["cat"].xmlCompact)
// prints Optional(AEXML.AEXMLError.elementNotFound)
print(xmlDoc["NotExistingElement"].error)
}
catch {
print("\(error)")
}
```### Write XML
Let's say this is some SOAP XML request you need to generate.
Well, you could just build ordinary string for that?```xml
234
AAPL
```
Yes, but, you can also do it in a more structured and elegant way with AEXML:
```swift
// create XML Document
let soapRequest = AEXMLDocument()
let attributes = ["xmlns:xsi" : "http://www.w3.org/2001/XMLSchema-instance", "xmlns:xsd" : "http://www.w3.org/2001/XMLSchema"]
let envelope = soapRequest.addChild(name: "soap:Envelope", attributes: attributes)
let header = envelope.addChild(name: "soap:Header")
let body = envelope.addChild(name: "soap:Body")
header.addChild(name: "m:Trans", value: "234", attributes: ["xmlns:m" : "http://www.w3schools.com/transaction/", "soap:mustUnderstand" : "1"])
let getStockPrice = body.addChild(name: "m:GetStockPrice")
getStockPrice.addChild(name: "m:StockName", value: "AAPL")// prints the same XML structure as original
print(soapRequest.xml)
```Or perhaps like this, using result builders (see [#186](https://github.com/tadija/AEXML/pull/186)):
```swift
@AEXMLDocumentBuilder
private func buildSoapEnvelope(
for action: String,
in serviceType: String,
with parameters: [String: String] = [:]
) -> AEXMLDocument {
AEXMLElement("s:Envelope", attributes: [
"xmlns:s": "http://schemas.xmlsoap.org/soap/envelope/",
"s:encodingStyle": "http://schemas.xmlsoap.org/soap/encoding/"
]) {
AEXMLElement("s:Body") {
AEXMLElement("s:\(action)", attributes: [
"xmlns:u": serviceType
]) {
for parameter in parameters {
AEXMLElement(
name: parameter.key,
value: parameter.value
)
}
}
}
}
}
```## Installation
- [Swift Package Manager](https://swift.org/package-manager/):
```swift
.package(url: "https://github.com/tadija/AEXML.git", from: "4.7.0")
```- [Carthage](https://github.com/Carthage/Carthage):
```ogdl
github "tadija/AEXML"
```- [CocoaPods](http://cocoapods.org/):
```ruby
pod 'AEXML'
```## License
AEXML is released under the MIT license. See [LICENSE](LICENSE) for details.