1. 拆分数组
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 | /// 根据 数组 截取 指定个数返回 多个数组的集合 func splitArray( array: [Date], withSubSize subSize: Int) -> [[Date]] { // 数组将被拆分成指定长度数组的个数 let count = array.count % subSize == 0 ? (array.count / subSize) : (array.count / subSize + 1) // 用来保存指定长度数组的可变数组对象 var arr: [[Date]] = [] //利用总个数进行循环,将指定长度的元素加入数组 for i in 0..<count { //数组下标 let index: Int = i * subSize //保存拆分的固定长度的数组元素的可变数组 var arr1: [Date] = [] //移除子数组的所有元素 arr1.removeAll() var j: Int = index //将数组下标乘以1、2、3,得到拆分时数组的最大下标值,但最大不能超过数组的总大小 while j < subSize * (i + 1) && j < array.count { arr1.append(array[j]) j += 1 } //将子数组添加到保存子数组的数组中 arr.append(arr1) } return arr } |
OC 拆分数组
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | #pragma mark -- 将数组拆分成固定长度 /** * 将数组拆分成固定长度的子数组 * * @param array 需要拆分的数组 * * @param subSize 指定长度 * */ - (NSArray *)splitArray: (NSArray *)array withSubSize : ( int )subSize{ // 数组将被拆分成指定长度数组的个数 unsigned long count = array.count % subSize == 0 ? (array.count / subSize) : (array.count / subSize + 1); // 用来保存指定长度数组的可变数组对象 NSMutableArray *arr = [[NSMutableArray alloc] init]; //利用总个数进行循环,将指定长度的元素加入数组 for ( int i = 0; i < count; i ++) { //数组下标 int index = i * subSize; //保存拆分的固定长度的数组元素的可变数组 NSMutableArray *arr1 = [[NSMutableArray alloc] init]; //移除子数组的所有元素 [arr1 removeAllObjects]; int j = index; //将数组下标乘以1、2、3,得到拆分时数组的最大下标值,但最大不能超过数组的总大小 while (j < subSize*(i + 1) && j < array.count) { [arr1 addObject:[array objectAtIndex:j]]; j += 1; } //将子数组添加到保存子数组的数组中 [arr addObject:[arr1 copy]]; } return [arr copy]; |
2. 拆分字符串
1 2 3 4 5 6 7 8 9 10 11 12 | func getWorkDayArr(workDay: String) -> [Int] { let separeArr = workDay.split(separator: "," ) var listArr: [Int] = [] if separeArr.count > 0 { for sub in separeArr { if let day = Int(sub) { listArr.append(day) } } } return listArr } |
分类:
swift
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现