Skip to main content

Quickly set up workflows for retrieving hard-to-find contact information and composing personalized messages based on any data point.

Project description

🧙 ContactMagic

What is ContactMagic?

ContactMagic is a wrapper around Copyfactory and SalesScrapers to build programmatic workflows that enrich contact data and create personalized and engaging messaging.

With ContactMagic, you can programmatically:

  • Enrich people and companies with hard to find datapoints such as case studies, news announcements and more.
  • Build your own custom scrapers in a few lines of code (Soon)
  • Bulk personalize and enrich data with as many datapoints as you need.
  • Create custom personalization templates.
  • Manage and run personalization workflows for clients at scale (contact eric@copyfactory.io to learn more)

Before you install

ContactMagic was designed with concurrency in mind. All operations make use of Asyncio to accelerate the process. You can set the number of concurrent workers in the settings.

Before installing, you should also ensure that you have a registered account with Copyfactory and SalesScrapers as API keys for both services is required.

Rate limit and error handling

There is no need for you to handle rate limits (429 HTTP status error). The library handles rate limits automatically.

Configuration

A 'SETTINGS' variable is exposed from the settings.py file which reads from your environment to set API key values.

Here are the current settings you should have in your .env file or environment.

COPYFACTORY_API_KEY=''
SALES_SCRAPERS_API_KEY=''
MASTERSHEET_URL=''
GOOGLE_PROJECT_ID=''
GOOGLE_PRIVATE_KEY_ID=''
GOOGLE_PRIVATE_KEY=''
GOOGLE_CLIENT_ID=''
GOOGLE_CLIENT_EMAIL=''
TIMEZONE="America/New_York"
# list and dict are parsed as JSON.
ALLOWED_SCRAPER_NAMES='["get-case-study", "get-company-achievement", "get-company-description", "get-company-announcement", "FALLBACK", "search-google"]'
MAX_WORKERS='5'  # Number of concurrent workers to process. 5-10 is likely enough.

If you are not using the agency workflows and just want to use the underlying PersonalizationSetttings objects you only need to set the following environment variables.

COPYFACTORY_API_KEY=''
SALES_SCRAPERS_API_KEY=''
# Optional since has default value
ALLOWED_SCRAPER_NAMES='["get-case-study", "get-company-achievement", "get-company-description", "get-company-announcement", "FALLBACK", "search-google"]'
# Optional since has default value
MAX_WORKERS='5'

Usage & Examples

The core underlying model you will be using is 'PersonalizationSettings' which is responsible for understanding what you want to scrape and how you want to personalize.

from contact_magic import PersonalizationSettings
import pandas as pd

data = [
    {
        # name this column anything you want
        "col_name": "personalized_field1",
        # If the first scraper returns nothing, will iterate through list until a successful scrape is complete.
        "allowed_scrapers": [
            {
                "scraper_name": "get-case-study",  # endpoint for SalesScrapers
                "premise_url": "https://app.copyfactory.io/profiles/1065/premises/7478/"  # Copyfactory premise url
            },
            {
                "scraper_name": "another-scraper",
                "premise_url": "https://app.copyfactory.io/profiles/1065/premises/7478/"
            }
        ],
    }, ...
]

# Set the datapoints. Notice how it's a list? This means you can generate as many personalized sentences as you want.
settings = PersonalizationSettings(datapoints=data)
dataframe = pd.read_csv("my_csv_file.csv")
# Run the settings against the DataFrame
personalized_dataframe = settings.process_from_dataframe(dataframe)

What happens when we run process_from_dataframe?

  1. The dataframe is extended with new columns. For each 'col_name' in the list of datapoints you provided a new column with the name you set for 'col_name' and another one for the source which is 'source__{col_name_value}' is added.
    • In our example above, the columns created would be 'personalized_field1' and 'source__personalized_field1'.
  2. For each datapoint, the list of 'allowed_scrapers' is iterated on and SalesScraper tries to find the data, if it does it sends the scraped data to Copyfactory to generate a personalized sentence.
  3. The source from SalesScrapers is set for that datapoints source column, and the personalized sentence is set on the datapoints column name.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

contact_magic-0.5.8.tar.gz (20.3 kB view details)

Uploaded Source

Built Distribution

contact_magic-0.5.8-py3-none-any.whl (25.5 kB view details)

Uploaded Python 3

File details

Details for the file contact_magic-0.5.8.tar.gz.

File metadata

  • Download URL: contact_magic-0.5.8.tar.gz
  • Upload date:
  • Size: 20.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.5.1 CPython/3.10.0 Darwin/21.4.0

File hashes

Hashes for contact_magic-0.5.8.tar.gz
Algorithm Hash digest
SHA256 ce63b5a9f2c855cc2295e66ad5bcfa63c1e1fefeccc1f9e30931e9aace5381e5
MD5 1e2074486704a987f20cfe727975f76b
BLAKE2b-256 815fba47a000dfabbf41cfa4cb8afc5ca64ad91c9f00d3c6a4090f8aa99dfb54

See more details on using hashes here.

File details

Details for the file contact_magic-0.5.8-py3-none-any.whl.

File metadata

  • Download URL: contact_magic-0.5.8-py3-none-any.whl
  • Upload date:
  • Size: 25.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.5.1 CPython/3.10.0 Darwin/21.4.0

File hashes

Hashes for contact_magic-0.5.8-py3-none-any.whl
Algorithm Hash digest
SHA256 302e4f557f739251d5f19ad2f12dff94a9becf2cf629a08007fd0d7c8dea3bf0
MD5 f7e524b198be5d9b3f122cd5bc372e35
BLAKE2b-256 1829f7aba2f0f31175d0cabae5d4114bec284f36ea423afab8d4e23054149ea8

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page