Android之使用ContentResolver对通信录中的数据进行简单操作

本文主要是介绍Android之使用ContentResolver对通信录中的数据进行简单操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.加入读写权限

Xhtml代码 复制代码
  1. <uses-permission android:name="android.permission.READ_CONTACTS" />
  2. <uses-permission android:name="android.permission.WRITE_CONTACTS" />

<uses-permission android:name="android.permission.READ_CONTACTS" /><uses-permission android:name="android.permission.WRITE_CONTACTS" />

联系人信息Uri:

content://com.android.contacts/contacts

联系人电话Uri:

content://com.android.contacts/data/phones

联系人Email Uri:

content://com.android.contacts/data/emails


(推荐)也可以这样获取联系人信息Uri:Uri uri = ContactsContract.Contacts.CONTENT_URI;



2.查询与添加联系人的操作(单元测试用例)


Java代码 复制代码
  1. public class ContactTest extends AndroidTestCase
  2. {
  3. private static final String TAG = "ContactTest";

  4. /**
  5. * 获取通讯录中所有联系人的简单信息
  6. * @throws Throwable
  7. */
  8. public void testGetAllContact() throws Throwable
  9. {
  10. //获取联系人信息的Uri
  11. Uri uri = ContactsContract.Contacts.CONTENT_URI;
  12. //获取ContentResolver
  13. ContentResolver contentResolver = this.getContext().getContentResolver();
  14. //查询数据,返回Cursor
  15. Cursor cursor = contentResolver.query(uri, null, null, null, null);
  16. while(cursor.moveToNext())
  17. {
  18. StringBuilder sb = new StringBuilder();
  19. //获取联系人的ID
  20. String contactId = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts._ID));
  21. //获取联系人的姓名
  22. String name = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts.DISPLAY_NAME));
  23. //构造联系人信息
  24. sb.append("contactId=").append(contactId).append(",Name=").append(name);
  25. //查询电话类型的数据操作
  26. Cursor phones = contentResolver.query(ContactsContract.CommonDataKinds.Phone.CONTENT_URI,
  27. null,
  28. ContactsContract.CommonDataKinds.Phone.CONTACT_ID +" = "+ contactId,
  29. null, null);
  30. while(phones.moveToNext())
  31. {
  32. String phoneNumber = phones.getString(phones.getColumnIndex(
  33. ContactsContract.CommonDataKinds.Phone.NUMBER));
  34. //添加Phone的信息
  35. sb.append(",Phone=").append(phoneNumber);
  36. }
  37. phones.close();

  38. //查询Email类型的数据操作
  39. Cursor emails = contentResolver.query(ContactsContract.CommonDataKinds.Email.CONTENT_URI,
  40. null,
  41. ContactsContract.CommonDataKinds.Email.CONTACT_ID + " = " + contactId,
  42. null, null);
  43. while (emails.moveToNext())
  44. {
  45. String emailAddress = emails.getString(emails.getColumnIndex(
  46. ContactsContract.CommonDataKinds.Email.DATA));
  47. //添加Email的信息
  48. sb.append(",Email=").append(emailAddress);
  49. }
  50. emails.close();
  51. Log.i(TAG, sb.toString());
  52. }
  53. cursor.close();
  54. }

  55. /**添加联系人的第一种方法:
  56. * 首先向RawContacts.CONTENT_URI执行一个空值插入,目的是获取系统返回的rawContactId
  57. * 这时后面插入data表的依据,只有执行空值插入,才能使插入的联系人在通讯录里面可见
  58. */
  59. public void testInsert()
  60. {
  61. ContentValues values = new ContentValues();
  62. //首先向RawContacts.CONTENT_URI执行一个空值插入,目的是获取系统返回的rawContactId
  63. Uri rawContactUri = this.getContext().getContentResolver().insert(RawContacts.CONTENT_URI, values);
  64. //获取id
  65. long rawContactId = ContentUris.parseId(rawContactUri);
  66. //往data表入姓名数据
  67. values.clear();
  68. values.put(Data.RAW_CONTACT_ID, rawContactId); //添加id
  69. values.put(Data.MIMETYPE, StructuredName.CONTENT_ITEM_TYPE);//添加内容类型(MIMETYPE)
  70. values.put(StructuredName.GIVEN_NAME, "凯风自南");//添加名字,添加到first name位置
  71. this.getContext().getContentResolver().insert(android.provider.ContactsContract.Data.CONTENT_URI, values);
  72. //往data表入电话数据
  73. values.clear();
  74. values.put(Data.RAW_CONTACT_ID, rawContactId);
  75. values.put(Data.MIMETYPE, Phone.CONTENT_ITEM_TYPE);
  76. values.put(Phone.NUMBER, "13921009789");
  77. values.put(Phone.TYPE, Phone.TYPE_MOBILE);
  78. this.getContext().getContentResolver().insert(android.provider.ContactsContract.Data.CONTENT_URI, values);
  79. //往data表入Email数据
  80. values.clear();
  81. values.put(Data.RAW_CONTACT_ID, rawContactId);
  82. values.put(Data.MIMETYPE, Email.CONTENT_ITEM_TYPE);
  83. values.put(Email.DATA, "kesenhoo@gmail.com");
  84. values.put(Email.TYPE, Email.TYPE_WORK);
  85. this.getContext().getContentResolver().insert(android.provider.ContactsContract.Data.CONTENT_URI, values);
  86. }

  87. /**添加联系人的第二种方法:
  88. * 批量添加联系人
  89. * @throws Throwable
  90. */
  91. public void testSave() throws Throwable
  92. {
  93. //官方文档位置:reference\android\provider\ContactsContract.RawContacts.html
  94. //建立一个ArrayList存放批量的参数
  95. ArrayList<ContentProviderOperation> ops = new ArrayList<ContentProviderOperation>();
  96. int rawContactInsertIndex = ops.size();
  97. ops.add(ContentProviderOperation.newInsert(RawContacts.CONTENT_URI)
  98. .withValue(RawContacts.ACCOUNT_TYPE, null)
  99. .withValue(RawContacts.ACCOUNT_NAME, null)
  100. .build());
  101. //官方文档位置:reference\android\provider\ContactsContract.Data.html
  102. //withValueBackReference后退引用前面联系人的id
  103. ops.add(ContentProviderOperation.newInsert(android.provider.ContactsContract.Data.CONTENT_URI)
  104. .withValueBackReference(Data.RAW_CONTACT_ID, rawContactInsertIndex)
  105. .withValue(Data.MIMETYPE, StructuredName.CONTENT_ITEM_TYPE)
  106. .withValue(StructuredName.GIVEN_NAME, "小明")
  107. .build());
  108. ops.add(ContentProviderOperation.newInsert(android.provider.ContactsContract.Data.CONTENT_URI)
  109. .withValueBackReference(Data.RAW_CONTACT_ID, rawContactInsertIndex)
  110. .withValue(Data.MIMETYPE, Phone.CONTENT_ITEM_TYPE)
  111. .withValue(Phone.NUMBER, "13671323809")
  112. .withValue(Phone.TYPE, Phone.TYPE_MOBILE)
  113. .withValue(Phone.LABEL, "手机号")
  114. .build());
  115. ops.add(ContentProviderOperation.newInsert(android.provider.ContactsContract.Data.CONTENT_URI)
  116. .withValueBackReference(Data.RAW_CONTACT_ID, rawContactInsertIndex)
  117. .withValue(Data.MIMETYPE, Email.CONTENT_ITEM_TYPE)
  118. .withValue(Email.DATA, "kesen@gmail.com")
  119. .withValue(Email.TYPE, Email.TYPE_WORK)
  120. .build());
  121. ContentProviderResult[] results = this.getContext().getContentResolver()
  122. .applyBatch(ContactsContract.AUTHORITY, ops);
  123. for(ContentProviderResult result : results)
  124. {
  125. Log.i(TAG, result.uri.toString());
  126. }
  127. }
  128. }

这篇关于Android之使用ContentResolver对通信录中的数据进行简单操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

关于数据埋点,你需要了解这些基本知识

产品汪每天都在和数据打交道,你知道数据来自哪里吗? 移动app端内的用户行为数据大多来自埋点,了解一些埋点知识,能和数据分析师、技术侃大山,参与到前期的数据采集,更重要是让最终的埋点数据能为我所用,否则可怜巴巴等上几个月是常有的事。   埋点类型 根据埋点方式,可以区分为: 手动埋点半自动埋点全自动埋点 秉承“任何事物都有两面性”的道理:自动程度高的,能解决通用统计,便于统一化管理,但个性化定

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

异构存储(冷热数据分离)

异构存储主要解决不同的数据,存储在不同类型的硬盘中,达到最佳性能的问题。 异构存储Shell操作 (1)查看当前有哪些存储策略可以用 [lytfly@hadoop102 hadoop-3.1.4]$ hdfs storagepolicies -listPolicies (2)为指定路径(数据存储目录)设置指定的存储策略 hdfs storagepolicies -setStoragePo

Hadoop集群数据均衡之磁盘间数据均衡

生产环境,由于硬盘空间不足,往往需要增加一块硬盘。刚加载的硬盘没有数据时,可以执行磁盘数据均衡命令。(Hadoop3.x新特性) plan后面带的节点的名字必须是已经存在的,并且是需要均衡的节点。 如果节点不存在,会报如下错误: 如果节点只有一个硬盘的话,不会创建均衡计划: (1)生成均衡计划 hdfs diskbalancer -plan hadoop102 (2)执行均衡计划 hd

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传