计算查询结果
您可以使用 matters.count 方法计算 Gmail 或 Google 网上论坛查询中的邮件数量,然后再创建导出。您可以使用此信息优化查询过滤器,并减少返回的结果数量。
如需使用 Google 保险柜资源,账号必须拥有所需的 Vault 权限 ,并且有权访问诉讼或调查。如需访问诉讼或调查,账号必须已创建诉讼或调查,或者诉讼或调查已与该账号共享,或者该账号拥有查看所有诉讼或调查 权限。
以下示例展示了如何计算查询返回的结果数量,这些结果是符合以下条件的邮件:
- 归账号
email1和email2所有的邮件。 - 排除草稿邮件。
- 发送给
ceo@solarmora.com的邮件。
Java
public Long count(Vault client, String matterId) { AccountInfo emailsToSearch = new AccountInfo().setEmails(ImmutableList.of("email1", "email2")); MailOptions mailQueryOptions = new MailOptions().setExcludeDrafts(true); String queryTerms = "to:ceo@solarmora.com"; Query query = new Query() .setCorpus("MAIL") .setDataScope("ALL_DATA") .setSearchMethod("ACCOUNT") .setAccountInfo(emailsToSearch) .setTerms(queryTerms); CountArtifactsRequest request = new CountArtifactsRequest().setQuery(query); Operation operation = client.matters().count(matterId, request).execute(); while(!operation.getDone()) { sleep(2000); operation = service.operations().get(operation.getName()).execute(); } if(operation.getResponse() != null) { return Long.parseLong(operation.getResponse.get("total_count").toString()); } return -1; }
Python
def count(service, matter_id): emails_to_search = ['email1', 'email2'] mail_query_options = {'excludeDrafts': True} query_terms = 'to:ceo@solarmora.com' mail_query = { 'corpus': 'MAIL', 'dataScope': 'ALL_DATA', 'searchMethod': 'ACCOUNT', 'accountInfo': { 'emails': emails_to_search }, 'terms': query_terms, 'mailOptions': mail_query_options, } request = { 'query': mail_query } operation = service.matters().count(matterId=matter_id, body=request).execute() while not operation.getDone(): time.sleep(2) operation = service.operations().get(name=operation.getName()).execute() if operation.getResponse() is None: return -1 return operation.getResponse()["total_count"]