使用欄位遮罩更新
透過集合功能整理內容
你可以依據偏好儲存及分類內容。
在 Google Ads API 中,更新作業是透過欄位遮罩完成。欄位遮罩會列出您打算透過更新變更的所有欄位,即使傳送至伺服器,系統也會忽略欄位遮罩中未列出的任何指定欄位。
欄位遮罩輔助工具
建議使用 google.api_core
套件中隨附的 field_mask
輔助函式產生欄位遮罩。這個函式會接受兩個 protobuf 物件,並傳回含有 list
欄位的欄位遮罩物件,其中包含兩個物件之間的所有不同欄位。
如果將 None
做為第一個參數傳遞,欄位遮罩清單只會包含第二個 protobuf 物件中,未設為預設值的所有欄位。
建構欄位遮罩物件後,應將其複製到要傳送至伺服器的作業物件:
以下是更新廣告活動的範例:
from google.api_core import protobuf_helpers
from google.ads.googleads.client import GoogleAdsClient
# Retrieve a GoogleAdsClient instance.
client = GoogleAdsClient.load_from_storage()
# Create a new campaign operation.
campaign_operation = client.get_type('CampaignOperation')
# Retrieve a new campaign object from its update field.
campaign = campaign_operation.update
# Mutate the campaign.
campaign.network_settings.target_search_network.value = False
# Create a field mask using the updated campaign.
# The field_mask helper is only compatible with raw protobuf message
# instances, which we can access using the ._pb attribute.
field_mask = protobuf_helpers.field_mask(None, campaign._pb)
# Copy the field_mask onto the operation's update_mask field.
client.copy_from(campaign_operation.update_mask, field_mask)
首先,我們建立空白的 CampaignOperation 物件。然後,我們從中擷取空白的 Campaign 物件。接著,我們會更新該廣告活動物件並建立新的欄位遮罩,與 None
比較後,只會產生包含已變更 network_settings.target_search_network
欄位的欄位遮罩清單。
以下是更新現有廣告活動的範例。假設指令碼已提供 resource_name
參數,該參數是廣告活動的有效資源名稱和有效 customer_id
:
import proto
from google.api_core import protobuf_helpers
from google.ads.googleads.client import GoogleAdsClient
# Retrieve a GoogleAdsClient instance.
client = GoogleAdsClient.load_from_storage()
# Retrieve an instance of the GoogleAdsService.
googleads_service = client.get_service('GoogleAdsService')
# Search query to retrieve campaign.
query = f"""
SELECT
campaign.network_settings.target_search_network,
campaign.resource_name
FROM campaign
WHERE campaign.resource_name = {resource_name}"""
# Submit a query to retrieve a campaign instance.
response = googleads_service.search_stream(customer_id=customer_id, query=query)
# Iterate over results to retrieve the campaign.
for batch in response:
for row in batch.results:
initial_campaign = row.campaign
# Create a new campaign operation.
campaign_operation = client.get_type('CampaignOperation')
# Set the copied campaign object to a variable for easy reference.
updated_campaign = campaign_operation.update
# Copy the retrieved campaign into the new campaign.
# Here we use the proto.Message.copy_from method because of its simple
# compatibility with the protobuf message instances, which are wrapped
# by the proto-plus library.
proto.Message.copy_from(updated_campaign, initial_campaign)
# Mutate the new campaign.
updated_campaign.network_settings.target_search_network = False
# Create a field mask using the updated campaign.
field_mask = protobuf_helpers.field_mask(
initial_campaign._pb, updated_campaign._pb
)
# Copy the field mask onto the operation's update_mask field.
# Note that the client's copy_from method is designed to work with both native
# messages and messages wrapped by proto-plus, so it works here for the
# update_mask, even though it's an instance of the native message class
# google.protobuf.field_mask_pb2.FieldMask.
client.copy_from(campaign_operation.update_mask, field_mask)
採用這項策略後,updated_campaign
會與從 API 擷取的 initial_campaign
共用所有相同欄位,也就是資源名稱。產生的欄位遮罩會告知 API,只需要變更 network_settings.target_search_network
欄位。
除非另有註明,否則本頁面中的內容是採用創用 CC 姓名標示 4.0 授權,程式碼範例則為阿帕契 2.0 授權。詳情請參閱《Google Developers 網站政策》。Java 是 Oracle 和/或其關聯企業的註冊商標。
上次更新時間:2025-08-27 (世界標準時間)。
[null,null,["上次更新時間:2025-08-27 (世界標準時間)。"],[[["\u003cp\u003eUpdates in the Google Ads API utilize a field mask to specify the fields to be changed, ignoring any other fields sent to the server.\u003c/p\u003e\n"],["\u003cp\u003eThe \u003ccode\u003efield_mask\u003c/code\u003e helper function from \u003ccode\u003egoogle.api_core\u003c/code\u003e simplifies field mask creation by comparing two protobuf objects.\u003c/p\u003e\n"],["\u003cp\u003eWhen \u003ccode\u003eNone\u003c/code\u003e is used as the first parameter in the \u003ccode\u003efield_mask\u003c/code\u003e helper, the generated mask includes only fields with non-default values.\u003c/p\u003e\n"],["\u003cp\u003eTo update an existing campaign, retrieve it first, modify the desired fields, and then utilize the \u003ccode\u003efield_mask\u003c/code\u003e helper for targeted updates.\u003c/p\u003e\n"],["\u003cp\u003eApply the generated field mask to the operation object's \u003ccode\u003eupdate_mask\u003c/code\u003e field before sending it to the server for processing.\u003c/p\u003e\n"]]],[],null,["# Updates Using Field Masks\n\nIn the Google Ads API, updates are done using a field mask. The field mask lists\nall the fields you intend to change with the update, and any specified fields\nthat are not in the field mask will be ignored, even if sent to the server.\n\nField mask helper\n-----------------\n\nThe recommended way to generate field masks is using the `field_mask` helper\nfunction included in the `google.api_core` package. It accepts two protobuf\nobjects and returns a field mask object with a `list` field that contains all\nof the fields that are different between the two objects.\n\nIf `None` is passed as the first parameter then the field mask list will just\ncontain all of the fields on the second protobuf object that are not set to\ntheir default value.\n\nOnce constructed the field mask object should be copied onto the operation\nobject that will be send to the server:\n\nHere's an example for updating a campaign: \n\n from google.api_core import protobuf_helpers\n from google.ads.googleads.client import GoogleAdsClient\n\n # Retrieve a GoogleAdsClient instance.\n client = GoogleAdsClient.load_from_storage()\n # Create a new campaign operation.\n campaign_operation = client.get_type('CampaignOperation')\n # Retrieve a new campaign object from its update field.\n campaign = campaign_operation.update\n # Mutate the campaign.\n campaign.network_settings.target_search_network.value = False\n\n # Create a field mask using the updated campaign.\n # The field_mask helper is only compatible with raw protobuf message\n # instances, which we can access using the ._pb attribute.\n field_mask = protobuf_helpers.field_mask(None, campaign._pb)\n\n # Copy the field_mask onto the operation's update_mask field.\n client.copy_from(campaign_operation.update_mask, field_mask)\n\nFirst, we create an empty CampaignOperation object. Then, we set retrieve an\nempty Campaign object from it. We then update that campaign object and create\na new field mask, comparing it to `None`, which will generate a field mask list\nthat only contains the `network_settings.target_search_network` field that was\nchanged.\n\nHere's an example updating an existing campaign. Here we assume the script has\nbeen provided a `resource_name` parameter that is a valid resource name for a\ncampaign and a valid `customer_id`: \n\n import proto\n\n from google.api_core import protobuf_helpers\n from google.ads.googleads.client import GoogleAdsClient\n\n # Retrieve a GoogleAdsClient instance.\n client = GoogleAdsClient.load_from_storage()\n # Retrieve an instance of the GoogleAdsService.\n googleads_service = client.get_service('GoogleAdsService')\n\n # Search query to retrieve campaign.\n query = f\"\"\"\n SELECT\n campaign.network_settings.target_search_network,\n campaign.resource_name\n FROM campaign\n WHERE campaign.resource_name = {resource_name}\"\"\"\n\n # Submit a query to retrieve a campaign instance.\n response = googleads_service.search_stream(customer_id=customer_id, query=query)\n\n # Iterate over results to retrieve the campaign.\n for batch in response:\n for row in batch.results:\n initial_campaign = row.campaign\n\n # Create a new campaign operation.\n campaign_operation = client.get_type('CampaignOperation')\n # Set the copied campaign object to a variable for easy reference.\n updated_campaign = campaign_operation.update\n # Copy the retrieved campaign into the new campaign.\n # Here we use the proto.Message.copy_from method because of its simple\n # compatibility with the protobuf message instances, which are wrapped\n # by the proto-plus library.\n proto.Message.copy_from(updated_campaign, initial_campaign)\n # Mutate the new campaign.\n updated_campaign.network_settings.target_search_network = False\n\n # Create a field mask using the updated campaign.\n field_mask = protobuf_helpers.field_mask(\n initial_campaign._pb, updated_campaign._pb\n )\n\n # Copy the field mask onto the operation's update_mask field.\n # Note that the client's copy_from method is designed to work with both native\n # messages and messages wrapped by proto-plus, so it works here for the\n # update_mask, even though it's an instance of the native message class\n # google.protobuf.field_mask_pb2.FieldMask.\n client.copy_from(campaign_operation.update_mask, field_mask)\n\nWith this strategy, the `updated_campaign` will share all the same fields as the\n`initial_campaign` that was retrieved from the API, namely the resource name.\nThe generated field mask will tell the API that only the\n`network_settings.target_search_network` field needs to be changed."]]