【我就看看不说话】读取通讯录

2024-08-27 07:58
文章标签 读取 通讯录 看看 说话

本文主要是介绍【我就看看不说话】读取通讯录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


一、在工程中添加AddressBook.frameworkAddressBookUI.framework


二、获取通讯录


1、在infterface中定义数组并在init方法中初始化


NSMutableArray *addressBookTemp;


- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil

{

    addressBookTemp = [NSMutableArray array];

}

2、定义一个model,用来存放通讯录中的各个属性

新建一个继承自NSObject的类,在.h



@interface TKAddressBook : NSObject {

    NSInteger sectionNumber;

    NSInteger recordID;

    NSString *name;

    NSString *email;

    NSString *tel;

}

@property NSInteger sectionNumber;

@property NSInteger recordID;

@property (nonatomic, retain) NSString *name;

@property (nonatomic, retain) NSString *email;

@property (nonatomic, retain) NSString *tel;


@end

.m文件中进行synthesize


@implementation TKAddressBook

@synthesize name, email, tel, recordID, sectionNumber;


@end

3、获取联系人


iOS6之后,获取通讯录需要获得权限



//新建一个通讯录类

ABAddressBookRef addressBooks = nil;


if([[UIDevice currentDevice].systemVersion floatValue] >= 6.0)


{

    addressBooks =  ABAddressBookCreateWithOptions(NULL, NULL);

    

    //获取通讯录权限

    

    dispatch_semaphore_t sema = dispatch_semaphore_create(0);

    

    ABAddressBookRequestAccessWithCompletion(addressBooks, ^(boolgranted, CFErrorRef error){dispatch_semaphore_signal(sema);});

    

    dispatch_semaphore_wait(sema, DISPATCH_TIME_FOREVER);

    

    dispatch_release(sema);

    

}


else


{

    addressBooks = ABAddressBookCreate();

    

}


//获取通讯录中的所有人

CFArrayRef allPeople = ABAddressBookCopyArrayOfAllPeople(addressBooks);



//通讯录中人数

CFIndex nPeople = ABAddressBookGetPersonCount(addressBooks);


//循环,获取每个人的个人信息

for(NSInteger i = 0; i < nPeople; i++)

{

    //新建一个addressBook model

    TKAddressBook *addressBook = [[TKAddressBook alloc] init];

    //获取个人

    ABRecordRef person = CFArrayGetValueAtIndex(allPeople, i);

    //获取个人名字

    CFTypeRef abName = ABRecordCopyValue(person, kABPersonFirstNameProperty);

    CFTypeRef abLastName = ABRecordCopyValue(person, kABPersonLastNameProperty);

    CFStringRef abFullName = ABRecordCopyCompositeName(person);

    NSString *nameString = (__bridge NSString *)abName;

    NSString *lastNameString = (__bridge NSString *)abLastName;

    

    if((__bridge id)abFullName != nil) {

        nameString = (__bridge NSString *)abFullName;

    }else{

        if((__bridge id)abLastName != nil)

        {

            nameString = [NSString stringWithFormat:@"%@ %@", nameString, lastNameString];

        }

    }

    addressBook.name = nameString;

    addressBook.recordID = (int)ABRecordGetRecordID(person);;

    

    ABPropertyID multiProperties[] = {

        kABPersonPhoneProperty,

        kABPersonEmailProperty

    };

    NSInteger multiPropertiesTotal = sizeof(multiProperties) / sizeof(ABPropertyID);

    for(NSInteger j = 0; j < multiPropertiesTotal; j++) {

        ABPropertyID property = multiProperties[j];

        ABMultiValueRef valuesRef = ABRecordCopyValue(person, property);

        NSInteger valuesCount = 0;

        if(valuesRef != nil) valuesCount = ABMultiValueGetCount(valuesRef);

        

        if(valuesCount == 0) {

            CFRelease(valuesRef);

            continue;

        }

        //获取电话号码和email

        for(NSInteger k = 0; k < valuesCount; k++) {

            CFTypeRef value = ABMultiValueCopyValueAtIndex(valuesRef, k);

            switch(j) {

                case0: {// Phone number

                    addressBook.tel = (__bridge NSString*)value;

                    break;

                }

                case1: {// Email

                    addressBook.email = (__bridge NSString*)value;

                    break;

                }

            }

            CFRelease(value);

        }

        CFRelease(valuesRef);

    }

    //将个人信息添加到数组中,循环完成后addressBookTemp中包含所有联系人的信息

    [addressBookTemp addObject:addressBook];

    

    if(abName) CFRelease(abName);

        if(abLastName) CFRelease(abLastName);

            if(abFullName) CFRelease(abFullName);

                }

三、显示在table


//行数

- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {

    return1;

}


//列数

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {

    return[addressBookTemp count];

}


//cell内容

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {

    

    NSString *cellIdentifier = @"ContactCell";

    

    UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:cellIdentifier];

    

    if(cell == nil){

        cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:cellIdentifier];

    }

    

    TKAddressBook *book = [addressBookTemp objectAtIndex:indexPath.row];

    

    cell.textLabel.text = book.name;

    

    cell.detailTextLabel.text = book.tel;

    

    returncell;

}

列表效果



这篇关于【我就看看不说话】读取通讯录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1111090

相关文章

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

Python使用openpyxl读取Excel的操作详解

《Python使用openpyxl读取Excel的操作详解》本文介绍了使用Python的openpyxl库进行Excel文件的创建、读写、数据操作、工作簿与工作表管理,包括创建工作簿、加载工作簿、操作... 目录1 概述1.1 图示1.2 安装第三方库2 工作簿 workbook2.1 创建:Workboo

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

SpringBoot读取ZooKeeper(ZK)属性的方法实现

《SpringBoot读取ZooKeeper(ZK)属性的方法实现》本文主要介绍了SpringBoot读取ZooKeeper(ZK)属性的方法实现,强调使用@ConfigurationProperti... 目录1. 在配置文件中定义 ZK 属性application.propertiesapplicati

Python中文件读取操作漏洞深度解析与防护指南

《Python中文件读取操作漏洞深度解析与防护指南》在Web应用开发中,文件操作是最基础也最危险的功能之一,这篇文章将全面剖析Python环境中常见的文件读取漏洞类型,成因及防护方案,感兴趣的小伙伴可... 目录引言一、静态资源处理中的路径穿越漏洞1.1 典型漏洞场景1.2 os.path.join()的陷

如何使用 Python 读取 Excel 数据

《如何使用Python读取Excel数据》:本文主要介绍使用Python读取Excel数据的详细教程,通过pandas和openpyxl,你可以轻松读取Excel文件,并进行各种数据处理操... 目录使用 python 读取 Excel 数据的详细教程1. 安装必要的依赖2. 读取 Excel 文件3. 读

Spring Boot读取配置文件的五种方式小结

《SpringBoot读取配置文件的五种方式小结》SpringBoot提供了灵活多样的方式来读取配置文件,这篇文章为大家介绍了5种常见的读取方式,文中的示例代码简洁易懂,大家可以根据自己的需要进... 目录1. 配置文件位置与加载顺序2. 读取配置文件的方式汇总方式一:使用 @Value 注解读取配置方式二

基于Python实现读取嵌套压缩包下文件的方法

《基于Python实现读取嵌套压缩包下文件的方法》工作中遇到的问题,需要用Python实现嵌套压缩包下文件读取,本文给大家介绍了详细的解决方法,并有相关的代码示例供大家参考,需要的朋友可以参考下... 目录思路完整代码代码优化思路打开外层zip压缩包并遍历文件:使用with zipfile.ZipFil

解决Java中基于GeoTools的Shapefile读取乱码的问题

《解决Java中基于GeoTools的Shapefile读取乱码的问题》本文主要讨论了在使用Java编程语言进行地理信息数据解析时遇到的Shapefile属性信息乱码问题,以及根据不同的编码设置进行属... 目录前言1、Shapefile属性字段编码的情况:一、Shp文件常见的字符集编码1、System编码