Swift_字典详解
Swift_字典详解
初始化
fileprivate func testInit() {
//空字典
var dic = [String:String]()
print(dic)
dic = [:]
print(dic)
dic = Dictionary()
print(dic)
dic = Dictionary<String,String>()
print(dic)
//非空字典
dic = ["name":"XuBaoAiChiYu","QQ":"1045214799"]
print(dic)
dic = Dictionary(dictionaryLiteral: ("name","XuBaoAiChiYu"),("QQ","1045214799"))
print(dic)
/* print
[:]
[:]
[:]
[:]
["name": "XuBaoAiChiYu", "QQ": "1045214799"]
["name": "XuBaoAiChiYu", "QQ": "1045214799"]
*/
}
相关属性
//相关属性
fileprivate func testProperties() {
let dic = ["name":"XuBaoAiChiYu","QQ":"1045214799"]
print(dic)
print("count:\(dic.count)") // 有多个对元素
print("isEmpty:\(dic.isEmpty)") // 是否为空
// 获取所有key
let keys = [String](dic.keys)
print("keys:\(keys)")
// 获取所有value
let values = [String](dic.values)
print("values:\(values)")
print("startIndex:\(dic.startIndex)") // 首脚标
print("endIndex:\(dic.endIndex)") // 尾脚标
/* print
["name": "XuBaoAiChiYu", "QQ": "1045214799"]
count:2
isEmpty:false
keys:["name", "QQ"]
values:["XuBaoAiChiYu", "1045214799"]
startIndex:DictionaryIndex<String, String>(_value: Swift.DictionaryIndexRepresentation<Swift.String, Swift.String>._native(Swift._NativeDictionaryIndex<Swift.String, Swift.String>(nativeStorage: , offset: 1)))
endIndex:DictionaryIndex<String, String>(_value: Swift.DictionaryIndexRepresentation<Swift.String, Swift.String>._native(Swift._NativeDictionaryIndex<Swift.String, Swift.String>(nativeStorage: , offset: 4)))
*/
}
查找元素
//查找元素
fileprivate func testFindingObjects() {
let dic = ["name":"XuBaoAiChiYu","QQ":"1045214799"]
print(dic)
if let dicIndex = dic.index(forKey: "name") { // 获取位置
let item = dic[dicIndex] // 根据位置获取键值对
print("key:\(item.0);value:\(item.1)")
}
let value = dic["name"] // 根据key提取Value
print("value:\(value)")
// 遍历输出
for (key, value) in dic {
print("\(key): \(value)")
}
// 所有key输出
for key in dic.keys {
print("key:\(key)")
}
// 所有value输出
for value in dic.values {
print("value: \(value)")
}
/* print
["name": "XuBaoAiChiYu", "QQ": "1045214799"]
key:name;value:XuBaoAiChiYu
value:Optional("XuBaoAiChiYu")
name: XuBaoAiChiYu
QQ: 1045214799
key:name
key:QQ
value: XuBaoAiChiYu
value: 1045214799
*/
}
增加元素
//增加元素
fileprivate func testAdd() {
var dic = ["name":"XuBaoAiChiYu","QQ":"1045214799"]
print(dic)
// 如果没有则添加,有则修改
dic["language"] = "swift"
print(dic)
/* print
["name": "XuBaoAiChiYu", "QQ": "1045214799"]
["language": "swift", "name": "XuBaoAiChiYu", "QQ": "1045214799"]
*/
}
删除元素
//删除元素
fileprivate func testRemove() {
var dic = ["name":"XuBaoAiChiYu","QQ":"1045214799"]
print(dic)
let oldValue = dic.removeValue(forKey: "name")// 根据key删除,并返回删除的value
print("\(oldValue)")
// 先找到位置,然后根据位置删除
if let dictIndex = dic.index(forKey: "QQ") {
let oldItem = dic.remove(at: dictIndex)// 返回删除的元素对
print("key:\(oldItem.0);value:\(oldItem.1)")
}
dic.removeAll() // 删除所有元素
print(dic)
/* print
["name": "XuBaoAiChiYu", "QQ": "1045214799"]
Optional("XuBaoAiChiYu")
key:QQ;value:1045214799
[:]
*/
}
修改元素
//修改元素
fileprivate func testReplace() {
var dic = ["name":"XuBaoAiChiYu","QQ":"1045214799"]
print(dic)
// 如果没有则添加,有则修改
dic["name"] = "XUBAO" // 修改
print(dic)
let oldValue = dic.updateValue("XUBAOAICHIYU", forKey: "name") // 修改,并返回原来的value
print("\(oldValue)")
/* print
["name": "XuBaoAiChiYu", "QQ": "1045214799"]
["name": "XUBAO", "QQ": "1045214799"]
Optional("XUBAO")
*/
}
排序
//排序
fileprivate func testSort() {
let dic = ["name":"XuBaoAiChiYu","QQ":"1045214799"]
print(dic)
// 排序主要只排序key或者value,然后借用Array的排序
// 排序key
var array = dic.keys.sorted(by: { str1,str2 in str1 < str2 })
array = dic.keys.sorted(by: <)
print(array)
// 排序value
array = dic.values.sorted(by: {$0 > $1})
print(array)
/* print
["name": "XuBaoAiChiYu", "QQ": "1045214799"]
["QQ", "name"]
["XuBaoAiChiYu", "1045214799"]
*/
}
文件读写
fileprivate func testReadingAndWriting() {
// Document目录
let documents:[String] = NSSearchPathForDirectoriesInDomains(FileManager.SearchPathDirectory.documentDirectory, FileManager.SearchPathDomainMask.userDomainMask, true)
let docDirPath = documents.first!
let path = (docDirPath as NSString).appendingPathComponent("test.plist")
let url = URL(fileURLWithPath: path)
var dic = ["name":"XuBaoAiChiYu","QQ":"1045214799"]
// 写
(dic as NSDictionary).write(toFile: path, atomically: true)
(dic as NSDictionary).write(to: url, atomically: true)
// 读
dic = NSDictionary(contentsOfFile: path) as! Dictionary
print(dic)
dic = NSDictionary(contentsOf: url) as! Dictionary
print(dic)
/* print
["name": "XuBaoAiChiYu", "QQ": "1045214799"]
["name": "XuBaoAiChiYu", "QQ": "1045214799"]
*/
}
Swift_字典详解的更多相关文章
- Swift_字符串详解(String)
Swift_字符串详解(String) 类型别名 //类型别名 fileprivate func testTypeAliases() { let index = String.Index.self p ...
- Swift_数组详解
Swift_数组详解 点击查看源码 初始化 //初始化 fileprivate func testInit() { //空数组 var array = [Int]() print(array) arr ...
- python七类之字典详解
一.字典 一.关键字:dict 1.字典是唯一的键值对数据,其表现形式: dic = {键:值},字典里的键必须保证是唯一的 2.键必须是不可变的数据类型: a.故列表是不能当键的 b.所 ...
- Python学习之字典详解
在元组和列表中,都是通过编号进行元素的访问,但有的时候我们按名字进行数据甚至数据结构的访问,在c++中有map的概念,也就是映射,在python中也提供了内置的映射类型--字典.映射其实就是一组key ...
- Python字典详解
转载请注明出处 Python字典(dict)是一个很常用的复合类型,其它常用符合类型有:数组(array).元组(touple)和集合(set).字典是一个key/value的集合,key可以是任意可 ...
- python 字典详解
1.字典的定义 字典类似于列表,但相对于列表来说字典更加通用,列表的下标必须必须为整数,而字典下标则可以为任意字符串/数字等,不可以是可变数据类型(列表,数组,元组) 字典包含下标(keys)集合和值 ...
- Python元组与字典详解
Python 元组 Python的元组与列表类似,不同之处在于元组的元素不能修改. 元组使用小括号,列表使用方括号. 元组创建很简单,只需要在括号中添加元素,并使用逗号隔开即可. 如下实例: tup ...
- Python之dict字典详解
Python内置了字典:dict的支持,dict全称dictionary,在其他语言中也称为map,字典是另 一种可变容器模型,且可存储任意类型对象.具有极快的查找速度. 字典是一种通过名字或者关键字 ...
- Python中的字典详解
https://www.cnblogs.com/yjd_hycf_space/p/6880026.html
随机推荐
- 信鸽推送 C#版SDK
信鸽官方sdk没提供C#版的DEMO,考虑到应该有其他.NET的也会用到信鸽,下面是我在使用信鸽过程中写的demo.有什么不对的地方,欢迎各位大牛指导. 使用过程中主要是有2个问题: 1.参数组装,本 ...
- 修改K3数据是简介方法
如 及时库存里有个别产品库存没有库位 是*号的 这个时候 我们创建一个其他出库单,把这个没有库位的产品输入进去,库位随便写个 如002 保存,审核不了的 会提示负库存 去后台找到此单据号 修改 ...
- Distinct 去掉重复 order by
语法: select distinct user from book select * from sdudant order by sex asc,sNo 从表sdudant查找已性别升序排序,性别相 ...
- Advanced .NET Debugging: Managed Heap and Garbage Collection(转载,托管堆查内存碎片问题解决思路)
原文地址:http://www.informit.com/articles/article.aspx?p=1409801&seqNum=4 Debugging Managed Heap Fra ...
- webpack起步
为什么要使用webpack 很牛逼的样子 https://www.webpackjs.com/comparison/ 基本概念 1. 入口(entry) module.exports = { entr ...
- Nginx集群(负载均衡)
一.集群介绍 1.传统web访问模型 (1)传统web访问模型完成一次请求的步骤 1)用户发起请求 2)服务器接受请求 3)服务器处理请求(压力最大) 4)服务器响应请求 (2)传统模型缺点 单点故障 ...
- 【Linux】GDB程序调试
一.GDB简介 GDB是GNU发布的一款功能强大的程序调试工具.GDB主要完成下面三个方面的功能: 启动被调试程序. 让被调试的程序在指定的位置停住. 当程序被停住时,可以检查程序状态(如变量值) 二 ...
- 【Mood-15】DailyBuild 1月
keywords: AsyncImageLoader universal-image-loader 2015-01-07 AsyncImageLoader:异步动态加载网络图片 类似listview ...
- sparkpython
http://blog.csdn.net/ydq1206/article/details/51922148
- Liunx网络管理
本地yum源 yum(Yellow dog Updater, Modified)是一个在 Fedora 和 RedHat 以及CentOS 中的 Shell 前端软件包管理器.基于 RPM 包管理,能 ...