Statsig is a multi-product feature flag, experimentation, and analytics platform. This means going from Statsig to PostHog requires migrating data from each product.
This guide walks through getting data from Statsig, converting it to the PostHog format, and using it to create or capture data in PostHog.
Differences between Statsig and PostHog
PostHog and Statsig have many of the same features and concepts, but different names and slight variations:
- Statsig has multiple types of feature and config management types including feature gates, experiments, dynamic configs, and parameter stores. In PostHog, the same functionality is all built on feature flags, including experiments. For example, a feature gate in Statsig is a boolean feature flag in PostHog and a parameter store is a flag with a JSON payload. 
- Dynamic configs are slightly different. They are a key that returns multiple different values depending on the targeting rules. To match this functionality in PostHog, you can use a multi-variant feature flag with JSON payloads and rely on “optional overrides” to target the specific variant. 
- Both primarily rely on a combination of rules and user IDs to target flags. Statsig also enables targeting by tags. You can recreate this functionality in PostHog by using person properties to set “tags” on users or groups. 
Learn more about how they compare in our PostHog vs Statsig comparison.
Getting your Statsig and PostHog API key
Accessing data via the Statsig API requires a console key. To create one, go to the Keys & Environments tab of your Statsig project settings. Click Generate New Key, select Console from the dropdown, make it read only, and click Create.

From PostHog, you need:
- Project ID: A number, likely 5 digits, that you can find in the URL of your project or your project settings. 
- Personal API key: To create one, go to the personal API key section of your project settings and click Create personal API key. Give it a label, write access to both experiments and feature flags, and then click Create key. Make sure to save it somewhere secure because you cannot access it later. 

Migrating feature gates from Statsig
Feature gates in Statsig turn into feature flags in PostHog. This conversion is straightforward, but because the targeting data structure is relatively complicated and customizable, you will need to redo it after creation.
Once migrated, you can go into each flag to set the targeting rules and enable or rollout the flag. You can also replace your statsig.checkGate calls with posthog.isFeatureEnabled ones.
Migrating dynamic configs from Statsig
The structure of feature flags in PostHog doesn't map perfectly to Statsig's dynamic config functionality. To migrate them, we set them up as feature flags with JSON payloads, but you need to set up the rules and optional overrides to match the targeting of your dynamic config. We keep the default value at 100% to match the Statsig behavior.
Once done, you can replace your statsig.getConfig call with a posthog.getFeatureFlagPayload one.
Note: As of writing this guide, Statsig does not have an endpoint for listing parameter stores, but you would follow a similar process to migrate them.
Migrating experiments from Statsig
Experiments between Statsig and PostHog are the most similar of the migrated data. Because they can be multi-variant and can have rules, we convert them in a similar way to dynamic configs. Some notes:
- PostHog requires the control key to be - control, so we need to convert whatever group is set as the control group in Statsig to the- controlkey.
- Because the structure of goal and secondary metrics are so different between the two, we don't include them in the experiments. You can change them after creation. 
- You can't add payloads (AKA parameters in Statsig) to the underlying feature flag via the experiments API. If you are relying on those, you must add them to the flag after creation. 
Once created, modify the goal and secondary metrics as well as the targeting to fit your needs and then launch your experiment.
Migrating events from Statsig
Prior to starting a historical data migration, ensure you do the following:
- Create a project on our US or EU Cloud.
- Sign up to a paid product analytics plan on the billing page (historic imports are free but this unlocks the necessary features).
- Set the
historical_migrationoption totruewhen capturing events in the migration.
Note: As of writing this guide, the Statsig event API was not returning events. This is written using a mix of their sample data and data returned from requests in-app.
The schema of Statsig's event data is similar to PostHog's schema, but it requires converting to work with the rest of PostHog's data. You can see details on Statsig's schema in their docs and events and properties PostHog autocaptures in our docs.
With Statsig's event data, you can go through each row and convert it to PostHog's schema. This requires converting:
- Event names like auto_capture::page_viewto$pageview.
- Properties like page_urlto$current_url
- Event timestampto an ISO 8601 timestamp
Once this is done, you can capture the data into PostHog using the Python SDK or the capture API endpoint with historical_migration set to true. You can find your project API key and host in your project settings. 
Here's an example Python script to convert Statsig's event data to PostHog's schema:
This script may need modification depending on the structure of your Statsig data, but it gives you a start.