Bulk Operations¶
Bulk operations let you create and distribute large numbers of gift cards in one job — without issuing them one at a time.

Three types of bulk jobs¶
| Job type | What it does | Best for |
|---|---|---|
| Generate | Creates codes with a set balance, no recipient | Export to CSV, physical card programs, internal use |
| Send | Creates codes and emails each one to a recipient | Corporate gifting, loyalty rewards, promotions |
| Update | Adjusts the balance on a set of existing cards | Adding bonus credit, correcting balances |
Bulk Generate¶
Use this to create a batch of gift card codes that you'll distribute yourself (e.g., export and print, add to packaging, hand to a partner).

Settings¶
| Field | Description |
|---|---|
| Quantity | Number of cards to generate (up to 10,000 per job) |
| Amount per card | Fixed balance loaded on each card |
| Expiry | Optional expiry date |
| Gift card type | Which design/settings template to use |
| Export format | CSV with code, balance, expiry, and status |
Generate without import¶
Use the Generate without import option for physical printed cards. This generates codes without activating them in Shopify — codes remain inactive until sold. Configure a prefix (up to 4 characters) and code length (8-16 characters).
After generation¶
When the job completes, you can download a CSV with all generated codes and their details. The codes are also live in Shopify as active gift cards (unless you used "Generate without import").
Bulk Send¶
Use this to send gift cards to a list of named recipients. Each person gets their own card and a personalized email.

Preparing your recipient list¶
Upload a CSV with the following columns:
| Column | Required | Description |
|---|---|---|
initial_value |
Yes | Amount in your store's currency |
email |
Yes | Recipient's email address |
name |
Optional | Recipient name, used in email greeting |
message |
Optional | Per-recipient personal message |
expires_on |
Optional | Expiry date in YYYY-MM-DD format |
Example CSV:
initial_value,email,name,message,expires_on
50,jane@example.com,Jane Smith,Thank you for your loyalty!,2027-03-15
100,bob@example.com,Bob Jones,Happy birthday Bob!,
Settings¶
- Default amount — used for rows that don't specify an amount
- Gift card type — design and settings template
- Sender name — shown in the email as "A gift from..."
- Default message — used when a row doesn't have a message column
- Schedule — send all at once or spread over time (e.g., 500/hour to avoid email throttling)
Sending throttle¶
For large lists (1,000+), GiftCard Hero spreads the sends over time to avoid hitting Shopify's email rate limits. You can set the rate in the advanced options.
Bulk Update¶
Adjust balances on a set of existing cards. Use cases:
- Add $10 bonus credit to all cards issued in a specific month
- Zero out cards that are past expiry
- Correct an incorrect balance after a system issue
Upload a CSV with the following columns:
| Column | Required | Description |
|---|---|---|
code |
Yes | The gift card code to update |
new_balance |
Optional | New balance value. Use + or - prefix for relative adjustments (e.g., +10.00 adds $10, -5.00 subtracts $5) |
disabled |
Optional | Set to TRUE to disable the card (irreversible) |
recipient_email |
Optional | Update the recipient email |
customer_email |
Optional | Update the customer email |
notify_customer |
Optional | Send notification to customer |
notify_recipient |
Optional | Send notification to recipient |
code,new_balance
ABCD-1234-EFGH-5678,75.00
IJKL-9012-MNOP-3456,+10.00
QRST-7890-UVWX-1234,-5.00
Note: Bulk Update sets the balance to the value you provide — it doesn't add or subtract — unless you use the
+or-prefix for relative adjustments. To add $10 to a card with $40, either setnew_balanceto50.00or use+10.00.
Bulk Import¶
Import existing gift cards from other systems into GiftCard Hero.
Upload a CSV with the following columns:
| Column | Required | Description |
|---|---|---|
initial_value |
Yes | Amount in your store's currency |
code |
Optional | Gift card code (auto-generated if omitted) |
customer_id |
Optional | Shopify customer ID to associate |
expires_on |
Optional | Expiry date in YYYY-MM-DD format |
recipient_email |
Optional | Recipient's email address |
customer_email |
Optional | Customer's email address |
notify_customer |
Optional | Send notification to customer |
notify_recipient |
Optional | Send notification to recipient |
Steps¶
- Navigate to the Import tab
- Prepare your CSV file with the columns above
- Upload the CSV file
- Click Start Import
Tracking results¶
After starting any bulk job, you can monitor progress in Bulk → Results.
The results page shows:
- Job status (queued, running, completed, failed)
- Progress (e.g., 847 / 1000 sent)
- Per-row errors (e.g., invalid email, duplicate code)
- Download links for the results CSV
Results CSV¶
The results CSV includes all input columns plus:
status— success / failed / skippederror— error message if failedhelpscout_url— public URL of the gift card (for Generate jobs)code_last4— last 4 digits of the gift card code
Limits and performance¶
| Limit | Value |
|---|---|
| Max cards per Generate job | 10,000 |
| Max rows per Send job | 10,000 |
| Max rows per Update job | 50,000 |
| Estimated speed (Generate) | ~500 cards/minute |
| Estimated speed (Send) | ~200 emails/minute |
Large jobs run in the background — you don't need to keep the browser open. You'll receive a summary email when the job completes.