Foundation框架: 8.OC中的集合类之一 - NSArray的基本认识

什么是集合类呢? 所谓的集合类就是可以把很多东西装在一起, 其实在C语言中我们也有对应的集合类, 那就数组, 在OC中有三个集合类, 分别是NSArray, NSSet, NSDictionay, 当然这里是包括他们的子类, 现在我们来看看集合类的第一个, NSArray:


我们都知道在C语言里面, 要存放多个内容, 那就必须得使用数组, 这样子我们才能把多个内容存入, 但C语言的数组有一个缺点, 就是存储的类型单一, 那么OC的数组又怎样呢? 下面来看看例子:

#import <Foundation/Foundation.h>

int main(int argc, const char * argv[])
{
    NSArray *ary = [[NSArray alloc] initWithObjects:@"1", @"2", nil];
    
    NSArray *ary1 = [NSArray arrayWithObject:@"a"];
    
    NSLog(@"ary = %@, ary1 = %@", ary, ary1);
    
    return 0;
}

打印出来的结果:

2015-02-04 18:58:05.637 4.NSArray[1980:303] 
ary = (
    1,
    2
), 
ary1 = (
    a
)

由于前面学习过一些Foundation的东西, 所以这里我就不解释为什么要这样子创建了, 因为这是OC语法中的一个规律.



NSArray还有一种快速的创建方法:

<span style="font-size:12px;">#import <Foundation/Foundation.h>

int main(int argc, const char * argv[])
{
    NSArray *ary = @[@"a", @"2", @"3", @"b"];
    
    NSLog(@"%@", ary);
    
    return 0;
}</span>

打印出来的结果:

<span style="font-size:12px;">2015-02-04 20:08:32.091 4.NSArray[2160:303] (
    a,
    2,
    3,
    b
)
</span>

以后在开发中, 我们都会经常使用到这种方法创建, 因为效率更高.




但NSArray也有几个缺点, 下面让我们来看看:

1.NSArray是不可变的

#import <Foundation/Foundation.h>

int main(int argc, const char * argv[])
{
    NSArray *ary = [NSArray array];
    
    return 0;
}

由于NSArray是不可变的, 如果按照上面的创建方法来创建, 那么ary这个数组永远都是空的数组, 不可以对它后期进行修改, 只有在该数组初始化的时候才能够赋值.



2.NSArray不能够添加非OC对象类型, 比如int, struct, enum等.



3.NSArray在添加多个对象的时候, 必须得以nil结尾, nilNSArray添加多个对象时结束的标志, 但如果初始化的时候有多个nil, 那么在第一个nil后面的元素就会当作是不存在, 比如:

#import <Foundation/Foundation.h>

int main(int argc, const char * argv[])
{
    
    NSArray *ary = [NSArray arrayWithObjects:nil, @"a", @"b", nil];
    
    NSLog(@"%ld", ary.count);
    
    return 0;
}


打印出来的结果:
2015-02-04 19:16:41.555 4.NSArray[2035:303] 0



在C语言里, 我们要获取数组里的某个元素, 就要写"类型名[元素位置]" 这样子去获取, 在NSArray中, 如果要获取某个位置的元素, 有两种方法:

#import <Foundation/Foundation.h>

int main(int argc, const char * argv[])
{
    
    NSArray *ary = [NSArray arrayWithObjects:@"a", @"b", nil];
    
    // 1.调用NSArray方法
    NSLog(@"%@", [ary objectAtIndex:1]);
    
    // 2.运用Xcode的特性
    NSLog(@"%@", ary[0]);
    
    return 0;
}

打印出来的结果:

2015-02-04 19:58:49.796 4.NSArray[2132:303] b
2015-02-04 19:58:49.797 4.NSArray[2132:303] a

第一种方法就不用多说了吧? 既然是面向对象的语言, 那就只有调用方法咯, 第二种方法是Xcode这个编译器的特性, 是Xcode特有的, 所以我们在实际开发过程中, 都是使用第二种方法, 因为它效率比第一种的高, 当然如果你想恶心自己或者想恶心别人的话, 你也可以去选择第一种, 但有被开除的风险~~~



NSArray的遍历有三种方法, 一种是普通遍历, 一种是快速遍历, 还有一种是block遍历,先来看看普通遍历:

#import <Foundation/Foundation.h>

int main(int argc, const char * argv[])
{
    NSArray *ary = @[@"a", @"b", @"c", @"d"];
    
    for (int i = 0; i < ary.count; i++)
    {
        NSLog(@"%@", ary[i]);
    }
    
    return 0;
}

打印出来的结果:

2015-02-04 20:23:28.260 4.NSArray[2267:303] a
2015-02-04 20:23:28.261 4.NSArray[2267:303] b
2015-02-04 20:23:28.262 4.NSArray[2267:303] c
2015-02-04 20:23:28.262 4.NSArray[2267:303] d

快速遍历:

#import <Foundation/Foundation.h>

int main(int argc, const char * argv[])
{
    NSArray *ary = @[@"a", @"b", @"c", @"d"];
    
    for (id obj in ary) 
    {
        NSUInteger i = [ary indexOfObject:obj];
        
        NSLog(@"%ld--%@", i, obj);
    }
    
    return 0;
}

快速遍历有一个缺点, 就是没办法知道是第几次的遍历, 为了解决这个问题, 所以添加了一个方法, 详情请看例子, 下面是打印出来的结果:

2015-02-04 20:32:05.759 4.NSArray[2285:303] 0--a
2015-02-04 20:32:05.760 4.NSArray[2285:303] 1--b
2015-02-04 20:32:05.760 4.NSArray[2285:303] 2--c
2015-02-04 20:32:05.760 4.NSArray[2285:303] 3--d


block遍历

#import <Foundation/Foundation.h>

int main(int argc, const char * argv[])
{
    NSArray *ary = @[@"a", @"b", @"c", @"d"];
    
    [ary enumerateObjectsUsingBlock:^(id obj, NSUInteger idx, BOOL *stop) {
        NSLog(@"%ld--%@", idx, obj);
    }];
    
    return 0;
}

打印出来的结果:

2015-02-04 20:38:22.097 4.NSArray[2304:303] 0--a
2015-02-04 20:38:22.098 4.NSArray[2304:303] 1--b
2015-02-04 20:38:22.098 4.NSArray[2304:303] 2--c
2015-02-04 20:38:22.099 4.NSArray[2304:303] 3--d

这里解释一下, 在enumerateObjectsUsingBlock: 这个方法里, 后面的那一大串其实是一个block, 我们前面知道了block是怎么定义以及使用的, 现在我们来到这个方法也是一样的, 只是这里把block当成参数传入进来, 而block里面有id, NSUInteger, BOOL这三个成员而已.


这里有人会问, 那里面的第三个成员是用来干嘛的? 别急, 让我们继续往下看:

#import <Foundation/Foundation.h>

int main(int argc, const char * argv[])
{
    NSArray *ary = @[@"a", @"b", @"c", @"d"];
    
    [ary enumerateObjectsUsingBlock:^(id obj, NSUInteger idx, BOOL *stop) {
        NSLog(@"%ld--%@", idx, obj);
        
        if (idx == 1)
        {
            *stop = YES;
        }
    }];
    
    return 0;
}

打印出来的结果:

2015-02-04 21:51:04.421 4.NSArray[2409:303] 0--a
2015-02-04 21:51:04.422 4.NSArray[2409:303] 1--b

其实里面的BOOL *stop指针是用来停止遍历的, 就和switch里面break作用一样, 有人又会问, 既然是作用一样, 为什么不直接就使用break呢? 其实break这个关键字, 并不是什么地方都可以使用, 它只能使用在switch, 还有循环体上, 在我们这个block遍历里, 没有循环体, 所以并不能在这里使用.






我解释一下这个方法的原理:

#import <Foundation/Foundation.h>

int main(int argc, const char * argv[])
{
    void ^(myblock)(id, NSUInteger, BOOL *) = ^(id obj, NSUInteger idx, BOOL *stop)
    {
        NSLog(@"%ld - %@", idx, obj);
        
        
        if (idx == 0)
        {
            // 停止遍历
            *stop = YES;
        }
    };
    
    for (int i = 0; i<array.count; i++)
    {
        // 用来标记是否需要停止遍历
        BOOL isStop = NO;
        
        // 取出元素
        id obj = array[i];
        
        myblock(obj, i, &isStop);
        
        if (isStop)
        {
            break;
        }
    }

    return 0;
}




好了, NSArray就讲到这里, 下次我们继续~~

在使用Python来安装geopandas包时,由于geopandas依赖于几个其他的Python库(如GDAL, Fiona, Pyproj, Shapely等),因此安装过程可能需要一些额外的步骤。以下是一个基本的安装指南,适用于大多数用户: 使用pip安装 确保Python和pip已安装: 首先,确保你的计算机上已安装了Python和pip。pip是Python的包管理工具,用于安装和管理Python包。 安装依赖库: 由于geopandas依赖于GDAL, Fiona, Pyproj, Shapely等库,你可能需要先安装这些库。通常,你可以通过pip直接安装这些库,但有时候可能需要从其他源下载预编译的二进制包(wheel文件),特别是GDAL和Fiona,因为它们可能包含一些系统级的依赖。 bash pip install GDAL Fiona Pyproj Shapely 注意:在某些系统上,直接使用pip安装GDAL和Fiona可能会遇到问题,因为它们需要编译一些C/C++代码。如果遇到问题,你可以考虑使用conda(一个Python包、依赖和环境管理器)来安装这些库,或者从Unofficial Windows Binaries for Python Extension Packages这样的网站下载预编译的wheel文件。 安装geopandas: 在安装了所有依赖库之后,你可以使用pip来安装geopandas。 bash pip install geopandas 使用conda安装 如果你正在使用conda作为你的Python包管理器,那么安装geopandas和它的依赖可能会更简单一些。 创建一个新的conda环境(可选,但推荐): bash conda create -n geoenv python=3.x anaconda conda activate geoenv 其3.x是你希望使用的Python版本。 安装geopandas: 使用conda-forge频道来安装geopandas,因为它提供了许多地理空间相关的包。 bash conda install -c conda-forge geopandas 这条命令会自动安装geopandas及其所有依赖。 注意事项 如果你在安装过程遇到任何问题,比如编译错误或依赖问题,请检查你的Python版本和pip/conda的版本是否是最新的,或者尝试在不同的环境安装。 某些库(如GDAL)可能需要额外的系统级依赖,如地理空间库(如PROJ和GEOS)。这些依赖可能需要单独安装,具体取决于你的操作系统。 如果你在Windows上遇到问题,并且pip安装失败,尝试从Unofficial Windows Binaries for Python Extension Packages网站下载相应的wheel文件,并使用pip进行安装。 脚本示例 虽然你的问题主要是关于如何安装geopandas,但如果你想要一个Python脚本来重命名文件夹下的文件,在原始名字前面加上字符串"geopandas",以下是一个简单的示例: python import os # 指定文件夹路径 folder_path = 'path/to/your/folder' # 遍历文件夹的文件 for filename in os.listdir(folder_path): # 构造原始文件路径 old_file_path = os.path.join(folder_path, filename) # 构造新文件名 new_filename = 'geopandas_' + filename # 构造新文件路径 new_file_path = os.path.join(folder_path, new_filename) # 重命名文件 os.rename(old_file_path, new_file_path) print(f'Renamed "{filename}" to "{new_filename}"') 请确保将'path/to/your/folder'替换为你想要重命名文件的实际文件夹路径。
在使用Python来安装geopandas包时,由于geopandas依赖于几个其他的Python库(如GDAL, Fiona, Pyproj, Shapely等),因此安装过程可能需要一些额外的步骤。以下是一个基本的安装指南,适用于大多数用户: 使用pip安装 确保Python和pip已安装: 首先,确保你的计算机上已安装了Python和pip。pip是Python的包管理工具,用于安装和管理Python包。 安装依赖库: 由于geopandas依赖于GDAL, Fiona, Pyproj, Shapely等库,你可能需要先安装这些库。通常,你可以通过pip直接安装这些库,但有时候可能需要从其他源下载预编译的二进制包(wheel文件),特别是GDAL和Fiona,因为它们可能包含一些系统级的依赖。 bash pip install GDAL Fiona Pyproj Shapely 注意:在某些系统上,直接使用pip安装GDAL和Fiona可能会遇到问题,因为它们需要编译一些C/C++代码。如果遇到问题,你可以考虑使用conda(一个Python包、依赖和环境管理器)来安装这些库,或者从Unofficial Windows Binaries for Python Extension Packages这样的网站下载预编译的wheel文件。 安装geopandas: 在安装了所有依赖库之后,你可以使用pip来安装geopandas。 bash pip install geopandas 使用conda安装 如果你正在使用conda作为你的Python包管理器,那么安装geopandas和它的依赖可能会更简单一些。 创建一个新的conda环境(可选,但推荐): bash conda create -n geoenv python=3.x anaconda conda activate geoenv 其3.x是你希望使用的Python版本。 安装geopandas: 使用conda-forge频道来安装geopandas,因为它提供了许多地理空间相关的包。 bash conda install -c conda-forge geopandas 这条命令会自动安装geopandas及其所有依赖。 注意事项 如果你在安装过程遇到任何问题,比如编译错误或依赖问题,请检查你的Python版本和pip/conda的版本是否是最新的,或者尝试在不同的环境安装。 某些库(如GDAL)可能需要额外的系统级依赖,如地理空间库(如PROJ和GEOS)。这些依赖可能需要单独安装,具体取决于你的操作系统。 如果你在Windows上遇到问题,并且pip安装失败,尝试从Unofficial Windows Binaries for Python Extension Packages网站下载相应的wheel文件,并使用pip进行安装。 脚本示例 虽然你的问题主要是关于如何安装geopandas,但如果你想要一个Python脚本来重命名文件夹下的文件,在原始名字前面加上字符串"geopandas",以下是一个简单的示例: python import os # 指定文件夹路径 folder_path = 'path/to/your/folder' # 遍历文件夹的文件 for filename in os.listdir(folder_path): # 构造原始文件路径 old_file_path = os.path.join(folder_path, filename) # 构造新文件名 new_filename = 'geopandas_' + filename # 构造新文件路径 new_file_path = os.path.join(folder_path, new_filename) # 重命名文件 os.rename(old_file_path, new_file_path) print(f'Renamed "{filename}" to "{new_filename}"') 请确保将'path/to/your/folder'替换为你想要重命名文件的实际文件夹路径。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值