# partnertransferbatch/TransferBatchApi 所有URI均基于微信支付 API 地址: *https://api.mch.weixin.qq.com* 方法名 | HTTP 请求 | 描述 ------------- | ------------- | ------------- [**GetTransferBatchByNo**](#gettransferbatchbyno) | **Get** /v3/partner-transfer/batches/batch-id/{batch_id} | 微信支付批次单号查询批次单 [**GetTransferBatchByOutNo**](#gettransferbatchbyoutno) | **Get** /v3/partner-transfer/batches/out-batch-no/{out_batch_no} | 商家批次单号查询批次单 [**InitiateTransferBatch**](#initiatetransferbatch) | **Post** /v3/partner-transfer/batches | 发起批量转账 ## GetTransferBatchByNo > TransferBatchEntity GetTransferBatchByNo(GetTransferBatchByNoRequest) 微信支付批次单号查询批次单 ### 调用示例 ```go package main import ( "context" "log" "github.com/wechatpay-apiv3/wechatpay-go/core" "github.com/wechatpay-apiv3/wechatpay-go/core/option" "github.com/wechatpay-apiv3/wechatpay-go/services/partnertransferbatch" "github.com/wechatpay-apiv3/wechatpay-go/utils" ) func main() { var ( mchID string = "190000****" // 商户号 mchCertificateSerialNumber string = "3775************************************" // 商户证书序列号 mchAPIv3Key string = "2ab9****************************" // 商户APIv3密钥 ) // 使用 utils 提供的函数从本地文件中加载商户私钥,商户私钥会用来生成请求的签名 mchPrivateKey, err := utils.LoadPrivateKeyWithPath("/path/to/merchant/apiclient_key.pem") if err != nil { log.Print("load merchant private key error") } ctx := context.Background() // 使用商户私钥等初始化 client,并使它具有自动定时获取微信支付平台证书的能力 opts := []core.ClientOption{ option.WithWechatPayAutoAuthCipher(mchID, mchCertificateSerialNumber, mchPrivateKey, mchAPIv3Key), } client, err := core.NewClient(ctx, opts...) if err != nil { log.Printf("new wechat pay client err:%s", err) } svc := partnertransferbatch.TransferBatchApiService{Client: client} resp, result, err := svc.GetTransferBatchByNo(ctx, partnertransferbatch.GetTransferBatchByNoRequest{ BatchId: core.String("1030000071100999991182020050700019480001"), NeedQueryDetail: core.Bool(true), Offset: core.Int64(0), Limit: core.Int64(20), DetailStatus: core.String("FAIL"), }, ) if err != nil { // 处理错误 log.Printf("call GetTransferBatchByNo err:%s", err) } else { // 处理返回结果 log.Printf("status=%d resp=%s", result.Response.StatusCode, resp) } } ``` ### 参数列表 参数名 | 参数类型 | 参数描述 ------------- | ------------- | ------------- **ctx** | **context.Context** | Golang 上下文,可用于日志、请求取消、请求跟踪等功能| **req** | [**GetTransferBatchByNoRequest**](GetTransferBatchByNoRequest.md) | API `partnertransferbatch` 所定义的本接口需要的所有参数,包括`Path`/`Query`/`Body` 3类参数| ### 返回结果 Name | Type | Description ------------- | ------------- | ------------- **resp** | \*[**TransferBatchEntity**](TransferBatchEntity.md) | 结构化的接口返回结果 **result** | **\*core.APIResult** | 本次 API 访问的请求与应答信息 **err** | **error** | 本次 API 访问中发生的错误,当且仅当 API 失败时存在 [\[返回顶部\]](#partnertransferbatchtransferbatchapi) [\[返回接口列表\]](README.md#接口列表) [\[返回类型列表\]](README.md#类型列表) [\[返回服务README\]](README.md) ## GetTransferBatchByOutNo > TransferBatchEntity GetTransferBatchByOutNo(GetTransferBatchByOutNoRequest) 商家批次单号查询批次单 ### 调用示例 ```go package main import ( "context" "log" "github.com/wechatpay-apiv3/wechatpay-go/core" "github.com/wechatpay-apiv3/wechatpay-go/core/option" "github.com/wechatpay-apiv3/wechatpay-go/services/partnertransferbatch" "github.com/wechatpay-apiv3/wechatpay-go/utils" ) func main() { var ( mchID string = "190000****" // 商户号 mchCertificateSerialNumber string = "3775************************************" // 商户证书序列号 mchAPIv3Key string = "2ab9****************************" // 商户APIv3密钥 ) // 使用 utils 提供的函数从本地文件中加载商户私钥,商户私钥会用来生成请求的签名 mchPrivateKey, err := utils.LoadPrivateKeyWithPath("/path/to/merchant/apiclient_key.pem") if err != nil { log.Print("load merchant private key error") } ctx := context.Background() // 使用商户私钥等初始化 client,并使它具有自动定时获取微信支付平台证书的能力 opts := []core.ClientOption{ option.WithWechatPayAutoAuthCipher(mchID, mchCertificateSerialNumber, mchPrivateKey, mchAPIv3Key), } client, err := core.NewClient(ctx, opts...) if err != nil { log.Printf("new wechat pay client err:%s", err) } svc := partnertransferbatch.TransferBatchApiService{Client: client} resp, result, err := svc.GetTransferBatchByOutNo(ctx, partnertransferbatch.GetTransferBatchByOutNoRequest{ OutBatchNo: core.String("plfk2020042013"), NeedQueryDetail: core.Bool(true), Offset: core.Int64(0), Limit: core.Int64(20), DetailStatus: core.String("FAIL"), }, ) if err != nil { // 处理错误 log.Printf("call GetTransferBatchByOutNo err:%s", err) } else { // 处理返回结果 log.Printf("status=%d resp=%s", result.Response.StatusCode, resp) } } ``` ### 参数列表 参数名 | 参数类型 | 参数描述 ------------- | ------------- | ------------- **ctx** | **context.Context** | Golang 上下文,可用于日志、请求取消、请求跟踪等功能| **req** | [**GetTransferBatchByOutNoRequest**](GetTransferBatchByOutNoRequest.md) | API `partnertransferbatch` 所定义的本接口需要的所有参数,包括`Path`/`Query`/`Body` 3类参数| ### 返回结果 Name | Type | Description ------------- | ------------- | ------------- **resp** | \*[**TransferBatchEntity**](TransferBatchEntity.md) | 结构化的接口返回结果 **result** | **\*core.APIResult** | 本次 API 访问的请求与应答信息 **err** | **error** | 本次 API 访问中发生的错误,当且仅当 API 失败时存在 [\[返回顶部\]](#partnertransferbatchtransferbatchapi) [\[返回接口列表\]](README.md#接口列表) [\[返回类型列表\]](README.md#类型列表) [\[返回服务README\]](README.md) ## InitiateTransferBatch > InitiateTransferBatchResponse InitiateTransferBatch(InitiateTransferBatchRequest) 发起批量转账 ### 调用示例 ```go package main import ( "context" "log" "github.com/wechatpay-apiv3/wechatpay-go/core" "github.com/wechatpay-apiv3/wechatpay-go/core/option" "github.com/wechatpay-apiv3/wechatpay-go/services/partnertransferbatch" "github.com/wechatpay-apiv3/wechatpay-go/utils" ) func main() { var ( mchID string = "190000****" // 商户号 mchCertificateSerialNumber string = "3775************************************" // 商户证书序列号 mchAPIv3Key string = "2ab9****************************" // 商户APIv3密钥 ) // 使用 utils 提供的函数从本地文件中加载商户私钥,商户私钥会用来生成请求的签名 mchPrivateKey, err := utils.LoadPrivateKeyWithPath("/path/to/merchant/apiclient_key.pem") if err != nil { log.Print("load merchant private key error") } ctx := context.Background() // 使用商户私钥等初始化 client,并使它具有自动定时获取微信支付平台证书的能力 opts := []core.ClientOption{ option.WithWechatPayAutoAuthCipher(mchID, mchCertificateSerialNumber, mchPrivateKey, mchAPIv3Key), } client, err := core.NewClient(ctx, opts...) if err != nil { log.Printf("new wechat pay client err:%s", err) } svc := partnertransferbatch.TransferBatchApiService{Client: client} resp, result, err := svc.InitiateTransferBatch(ctx, partnertransferbatch.InitiateTransferBatchRequest{ SubMchid: core.String("1900000109"), SubAppid: core.String("wxf636efh567hg4356"), AuthorizationType: partnertransferbatch.AUTHTYPE_INFORMATION_AUTHORIZATION_TYPE.Ptr(), OutBatchNo: core.String("plfk2020042013"), BatchName: core.String("2019年1月深圳分部报销单"), BatchRemark: core.String("2019年1月深圳分部报销单"), TotalAmount: core.Int64(4000000), TotalNum: core.Int64(200), TransferDetailList: []partnertransferbatch.TransferDetailInput{partnertransferbatch.TransferDetailInput{ Openid: core.String("o-MYE42l80oelYMDE34nYD456Xoy"), OutDetailNo: core.String("x23zy545Bd5436"), TransferAmount: core.Int64(200000), TransferRemark: core.String("2020年4月报销"), UserIdCard: core.String("UserIdCard_example"), UserName: core.String("UserName_example"), }}, SpAppid: core.String("wxf636efh567hg4388"), TransferPurpose: partnertransferbatch.TRANSFERUSETYPE_GOODSPAYMENT.Ptr(), TransferScene: partnertransferbatch.TRANSFERSCENE_ORDINARY_TRANSFER.Ptr(), }, ) if err != nil { // 处理错误 log.Printf("call InitiateTransferBatch err:%s", err) } else { // 处理返回结果 log.Printf("status=%d resp=%s", result.Response.StatusCode, resp) } } ``` ### 参数列表 参数名 | 参数类型 | 参数描述 ------------- | ------------- | ------------- **ctx** | **context.Context** | Golang 上下文,可用于日志、请求取消、请求跟踪等功能| **req** | [**InitiateTransferBatchRequest**](InitiateTransferBatchRequest.md) | API `partnertransferbatch` 所定义的本接口需要的所有参数,包括`Path`/`Query`/`Body` 3类参数| ### 返回结果 Name | Type | Description ------------- | ------------- | ------------- **resp** | \*[**InitiateTransferBatchResponse**](InitiateTransferBatchResponse.md) | 结构化的接口返回结果 **result** | **\*core.APIResult** | 本次 API 访问的请求与应答信息 **err** | **error** | 本次 API 访问中发生的错误,当且仅当 API 失败时存在 [\[返回顶部\]](#partnertransferbatchtransferbatchapi) [\[返回接口列表\]](README.md#接口列表) [\[返回类型列表\]](README.md#类型列表) [\[返回服务README\]](README.md)