{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import requests\n",
    "import polygon\n",
    "\n",
    "client = polygon.RESTClient(\"NbOaYW2hvhGCEKNKaUeVI3iNg1P40Sie\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "us_ticker_list_fpath = '/root/XXX/Data/my_data_dir/main/us/instruments/all.txt'\n",
    "with open(us_ticker_list_fpath) as f:\n",
    "    us_ticker_list = f.read().splitlines()\n",
    "us_stocks = [x.split('\\t')[0] for x in us_ticker_list]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# For a frequency, get aggregate bars for all stocks\n",
    "import pandas as pd\n",
    "from datetime import datetime\n",
    "\n",
    "\n",
    "def get_aggs_for_all_stocks(freq, start, end):\n",
    "    print(f\"Getting {freq} bars for all stocks from {start} to {end}\")\n",
    "    all_aggs = {}\n",
    "\n",
    "    def stock_worker(stock) -> pd.Series:\n",
    "        client = polygon.RESTClient(\"NbOaYW2hvhGCEKNKaUeVI3iNg1P40Sie\")\n",
    "        aggs = client.get_aggs(\n",
    "            ticker=stock, multiplier=1, timespan=freq, from_=start, to=end\n",
    "        )\n",
    "        # for each field, return a series\n",
    "        time_indices = [\n",
    "            datetime.fromtimestamp(x.timestamp / 1000.0) for x in aggs\n",
    "        ]\n",
    "        time_indices = [x.strftime(\"%Y%m%dT%H%M%S\") for x in time_indices]\n",
    "        open_prices = [x.open for x in aggs]\n",
    "        high_prices = [x.high for x in aggs]\n",
    "        low_prices = [x.low for x in aggs]\n",
    "        close_prices = [x.close for x in aggs]\n",
    "        volumes = [x.volume for x in aggs]\n",
    "        vwaps = [x.vwap for x in aggs]\n",
    "        # amounts = [x.volume * x.vwap for x in aggs]\n",
    "        ntrades = [x.transactions for x in aggs]\n",
    "        series_dict = {\n",
    "            \"open\": pd.Series(open_prices, index=time_indices, name=stock),\n",
    "            \"close\": pd.Series(close_prices, index=time_indices, name=stock),\n",
    "            \"high\": pd.Series(high_prices, index=time_indices, name=stock),\n",
    "            \"low\": pd.Series(low_prices, index=time_indices, name=stock),\n",
    "            \"volume\": pd.Series(volumes, index=time_indices, name=stock),\n",
    "            \"vwap\": pd.Series(vwaps, index=time_indices, name=stock),\n",
    "            # \"amount\": pd.Series(amounts, index=time_indices, name=stock),\n",
    "            \"ntrades\": pd.Series(ntrades, index=time_indices, name=stock),\n",
    "        }\n",
    "        return series_dict\n",
    "\n",
    "    import loky\n",
    "    from tqdm import tqdm\n",
    "\n",
    "    with loky.get_reusable_executor(128) as e:\n",
    "        all_series = [x for x in tqdm(e.map(stock_worker, us_stocks), total_length=len(us_stocks))]\n",
    "        # For each data field, make a dataframe with each column as a stock\n",
    "        for field in all_series[0].keys():\n",
    "            all_aggs[field] = pd.concat([x[field] for x in all_series], axis=1)\n",
    "    return all_aggs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 6375/6375 [00:25<00:00, 249.05it/s]\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "day_vp_dir = '/root/XXX/Data/my_data_dir/main/us/aggs'\n",
    "files = os.listdir(day_vp_dir)\n",
    "from tqdm import tqdm\n",
    "data_dict = {}\n",
    "for f in tqdm(files):\n",
    "    if not f.endswith('.csv'):\n",
    "        continue\n",
    "    data = pd.read_csv(os.path.join(day_vp_dir, f), index_col=0)\n",
    "    stock = f.split('.')[0]\n",
    "    for col in data.columns:\n",
    "        data_dict.setdefault(col, {})[stock] = data[col]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>SIX</th>\n",
       "      <th>NIHDQ</th>\n",
       "      <th>SSNT</th>\n",
       "      <th>MOG-A</th>\n",
       "      <th>EPOW</th>\n",
       "      <th>JILL</th>\n",
       "      <th>FSNB</th>\n",
       "      <th>AEHL</th>\n",
       "      <th>RXRX</th>\n",
       "      <th>PLAO</th>\n",
       "      <th>...</th>\n",
       "      <th>MPTI</th>\n",
       "      <th>ABST</th>\n",
       "      <th>SHEN</th>\n",
       "      <th>VZ</th>\n",
       "      <th>ENZ</th>\n",
       "      <th>EBAY</th>\n",
       "      <th>WORX</th>\n",
       "      <th>RUSHB</th>\n",
       "      <th>TWLVU</th>\n",
       "      <th>SXT</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>20040102T130000</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>27774.8</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>48600.0</td>\n",
       "      <td>7281100.0</td>\n",
       "      <td>163590.0</td>\n",
       "      <td>4.327784e+07</td>\n",
       "      <td>NaN</td>\n",
       "      <td>35926.875</td>\n",
       "      <td>NaN</td>\n",
       "      <td>108800.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20040105T130000</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>34897.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>61368.0</td>\n",
       "      <td>14689900.0</td>\n",
       "      <td>211890.0</td>\n",
       "      <td>6.230877e+07</td>\n",
       "      <td>NaN</td>\n",
       "      <td>25312.500</td>\n",
       "      <td>NaN</td>\n",
       "      <td>206000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20040106T130000</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>23967.4</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>25764.0</td>\n",
       "      <td>9881200.0</td>\n",
       "      <td>201495.0</td>\n",
       "      <td>4.030268e+07</td>\n",
       "      <td>NaN</td>\n",
       "      <td>68863.500</td>\n",
       "      <td>NaN</td>\n",
       "      <td>206200.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20040107T130000</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>27367.4</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>171468.0</td>\n",
       "      <td>9364100.0</td>\n",
       "      <td>127785.0</td>\n",
       "      <td>3.068029e+07</td>\n",
       "      <td>NaN</td>\n",
       "      <td>82350.000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>180800.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20040108T130000</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>18720.4</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>76800.0</td>\n",
       "      <td>9237100.0</td>\n",
       "      <td>311220.0</td>\n",
       "      <td>3.843320e+07</td>\n",
       "      <td>NaN</td>\n",
       "      <td>79261.875</td>\n",
       "      <td>NaN</td>\n",
       "      <td>209900.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20240520T120000</th>\n",
       "      <td>541148.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>24528.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>4834.0</td>\n",
       "      <td>51616.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>71069.0</td>\n",
       "      <td>3484861.0</td>\n",
       "      <td>450768.0</td>\n",
       "      <td>...</td>\n",
       "      <td>32338.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>12149.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20240521T120000</th>\n",
       "      <td>729688.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>22864.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>3146.0</td>\n",
       "      <td>22897.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>290539.0</td>\n",
       "      <td>3014821.0</td>\n",
       "      <td>201602.0</td>\n",
       "      <td>...</td>\n",
       "      <td>42222.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>19713.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20240522T120000</th>\n",
       "      <td>691345.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>24738.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>3080.0</td>\n",
       "      <td>36742.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>69169.0</td>\n",
       "      <td>3587831.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>29156.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>32031.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20240523T120000</th>\n",
       "      <td>943453.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>36614.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>6233.0</td>\n",
       "      <td>65920.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>21995.0</td>\n",
       "      <td>6667755.0</td>\n",
       "      <td>50613.0</td>\n",
       "      <td>...</td>\n",
       "      <td>40802.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>78568.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20240524T120000</th>\n",
       "      <td>586561.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>61560.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>2341.0</td>\n",
       "      <td>26253.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>8560.0</td>\n",
       "      <td>3401122.0</td>\n",
       "      <td>50046.0</td>\n",
       "      <td>...</td>\n",
       "      <td>41860.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>3615875.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5134 rows × 6373 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                      SIX NIHDQ     SSNT MOG-A    EPOW     JILL  FSNB  \\\n",
       "20040102T130000       NaN   NaN      NaN   NaN     NaN  27774.8   NaN   \n",
       "20040105T130000       NaN   NaN      NaN   NaN     NaN  34897.0   NaN   \n",
       "20040106T130000       NaN   NaN      NaN   NaN     NaN  23967.4   NaN   \n",
       "20040107T130000       NaN   NaN      NaN   NaN     NaN  27367.4   NaN   \n",
       "20040108T130000       NaN   NaN      NaN   NaN     NaN  18720.4   NaN   \n",
       "...                   ...   ...      ...   ...     ...      ...   ...   \n",
       "20240520T120000  541148.0   NaN  24528.0   NaN  4834.0  51616.0   NaN   \n",
       "20240521T120000  729688.0   NaN  22864.0   NaN  3146.0  22897.0   NaN   \n",
       "20240522T120000  691345.0   NaN  24738.0   NaN  3080.0  36742.0   NaN   \n",
       "20240523T120000  943453.0   NaN  36614.0   NaN  6233.0  65920.0   NaN   \n",
       "20240524T120000  586561.0   NaN  61560.0   NaN  2341.0  26253.0   NaN   \n",
       "\n",
       "                     AEHL       RXRX      PLAO  ...     MPTI  ABST      SHEN  \\\n",
       "20040102T130000       NaN        NaN       NaN  ...      NaN   NaN   48600.0   \n",
       "20040105T130000       NaN        NaN       NaN  ...      NaN   NaN   61368.0   \n",
       "20040106T130000       NaN        NaN       NaN  ...      NaN   NaN   25764.0   \n",
       "20040107T130000       NaN        NaN       NaN  ...      NaN   NaN  171468.0   \n",
       "20040108T130000       NaN        NaN       NaN  ...      NaN   NaN   76800.0   \n",
       "...                   ...        ...       ...  ...      ...   ...       ...   \n",
       "20240520T120000   71069.0  3484861.0  450768.0  ...  32338.0   NaN       NaN   \n",
       "20240521T120000  290539.0  3014821.0  201602.0  ...  42222.0   NaN       NaN   \n",
       "20240522T120000   69169.0  3587831.0       NaN  ...  29156.0   NaN       NaN   \n",
       "20240523T120000   21995.0  6667755.0   50613.0  ...  40802.0   NaN       NaN   \n",
       "20240524T120000    8560.0  3401122.0   50046.0  ...  41860.0   NaN       NaN   \n",
       "\n",
       "                         VZ       ENZ          EBAY       WORX      RUSHB  \\\n",
       "20040102T130000   7281100.0  163590.0  4.327784e+07        NaN  35926.875   \n",
       "20040105T130000  14689900.0  211890.0  6.230877e+07        NaN  25312.500   \n",
       "20040106T130000   9881200.0  201495.0  4.030268e+07        NaN  68863.500   \n",
       "20040107T130000   9364100.0  127785.0  3.068029e+07        NaN  82350.000   \n",
       "20040108T130000   9237100.0  311220.0  3.843320e+07        NaN  79261.875   \n",
       "...                     ...       ...           ...        ...        ...   \n",
       "20240520T120000         NaN       NaN           NaN    12149.0        NaN   \n",
       "20240521T120000         NaN       NaN           NaN    19713.0        NaN   \n",
       "20240522T120000         NaN       NaN           NaN    32031.0        NaN   \n",
       "20240523T120000         NaN       NaN           NaN    78568.0        NaN   \n",
       "20240524T120000         NaN       NaN           NaN  3615875.0        NaN   \n",
       "\n",
       "                 TWLVU       SXT  \n",
       "20040102T130000    NaN  108800.0  \n",
       "20040105T130000    NaN  206000.0  \n",
       "20040106T130000    NaN  206200.0  \n",
       "20040107T130000    NaN  180800.0  \n",
       "20040108T130000    NaN  209900.0  \n",
       "...                ...       ...  \n",
       "20240520T120000    NaN       NaN  \n",
       "20240521T120000    NaN       NaN  \n",
       "20240522T120000    NaN       NaN  \n",
       "20240523T120000    NaN       NaN  \n",
       "20240524T120000    NaN       NaN  \n",
       "\n",
       "[5134 rows x 6373 columns]"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pd.DataFrame(data_dict['volume'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saved Unnamed: 0\n",
      "Saved open\n",
      "Saved close\n",
      "Saved high\n",
      "Saved low\n",
      "Saved volume\n",
      "Saved vwap\n",
      "Saved ntrades\n"
     ]
    }
   ],
   "source": [
    "df_dict = {}\n",
    "os.makedirs('/root/XXX/Data/my_data_dir/main/us/aggs/full', exist_ok=True)\n",
    "for field in data_dict.keys():\n",
    "    data = pd.DataFrame(data_dict[field])\n",
    "    data.to_csv(f'/root/XXX/Data/my_data_dir/main/us/aggs/full/{field}.csv')\n",
    "    print(f\"Saved {field}\")\n",
    "    df_dict[field] = data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "ticks = df_dict['Unnamed: 0']['AAPL']\n",
    "ticks = ticks.values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>SIX</th>\n",
       "      <th>NIHDQ</th>\n",
       "      <th>SSNT</th>\n",
       "      <th>MOG-A</th>\n",
       "      <th>EPOW</th>\n",
       "      <th>JILL</th>\n",
       "      <th>FSNB</th>\n",
       "      <th>AEHL</th>\n",
       "      <th>RXRX</th>\n",
       "      <th>PLAO</th>\n",
       "      <th>...</th>\n",
       "      <th>MPTI</th>\n",
       "      <th>ABST</th>\n",
       "      <th>SHEN</th>\n",
       "      <th>VZ</th>\n",
       "      <th>ENZ</th>\n",
       "      <th>EBAY</th>\n",
       "      <th>WORX</th>\n",
       "      <th>RUSHB</th>\n",
       "      <th>TWLVU</th>\n",
       "      <th>SXT</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>2.1775</td>\n",
       "      <td>NaN</td>\n",
       "      <td>4.3000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>2.230</td>\n",
       "      <td>63.65</td>\n",
       "      <td>9.80</td>\n",
       "      <td>23.701</td>\n",
       "      <td>30.0000</td>\n",
       "      <td>10.0300</td>\n",
       "      <td>...</td>\n",
       "      <td>13.30</td>\n",
       "      <td>11.00</td>\n",
       "      <td>4.4000</td>\n",
       "      <td>35.10</td>\n",
       "      <td>17.1429</td>\n",
       "      <td>13.5438</td>\n",
       "      <td>48.00</td>\n",
       "      <td>2.8652</td>\n",
       "      <td>10.0200</td>\n",
       "      <td>19.87</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2.1675</td>\n",
       "      <td>NaN</td>\n",
       "      <td>4.2700</td>\n",
       "      <td>NaN</td>\n",
       "      <td>3.050</td>\n",
       "      <td>64.80</td>\n",
       "      <td>9.80</td>\n",
       "      <td>23.100</td>\n",
       "      <td>28.6774</td>\n",
       "      <td>10.0301</td>\n",
       "      <td>...</td>\n",
       "      <td>16.72</td>\n",
       "      <td>11.80</td>\n",
       "      <td>4.3167</td>\n",
       "      <td>35.50</td>\n",
       "      <td>17.2381</td>\n",
       "      <td>13.3228</td>\n",
       "      <td>60.45</td>\n",
       "      <td>2.8741</td>\n",
       "      <td>10.0662</td>\n",
       "      <td>20.06</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2.2000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>4.0000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>2.590</td>\n",
       "      <td>66.80</td>\n",
       "      <td>9.80</td>\n",
       "      <td>24.200</td>\n",
       "      <td>27.3200</td>\n",
       "      <td>10.1000</td>\n",
       "      <td>...</td>\n",
       "      <td>14.04</td>\n",
       "      <td>11.73</td>\n",
       "      <td>4.3500</td>\n",
       "      <td>36.25</td>\n",
       "      <td>17.5238</td>\n",
       "      <td>13.5817</td>\n",
       "      <td>125.25</td>\n",
       "      <td>2.8385</td>\n",
       "      <td>10.0700</td>\n",
       "      <td>20.34</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>2.0575</td>\n",
       "      <td>NaN</td>\n",
       "      <td>4.2237</td>\n",
       "      <td>NaN</td>\n",
       "      <td>2.300</td>\n",
       "      <td>66.35</td>\n",
       "      <td>9.85</td>\n",
       "      <td>24.800</td>\n",
       "      <td>29.5000</td>\n",
       "      <td>10.0800</td>\n",
       "      <td>...</td>\n",
       "      <td>11.94</td>\n",
       "      <td>11.35</td>\n",
       "      <td>4.4084</td>\n",
       "      <td>36.45</td>\n",
       "      <td>17.6190</td>\n",
       "      <td>13.6953</td>\n",
       "      <td>100.95</td>\n",
       "      <td>2.9926</td>\n",
       "      <td>10.0600</td>\n",
       "      <td>20.08</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>2.0000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>4.1000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>2.181</td>\n",
       "      <td>66.90</td>\n",
       "      <td>9.80</td>\n",
       "      <td>24.500</td>\n",
       "      <td>33.6400</td>\n",
       "      <td>10.0200</td>\n",
       "      <td>...</td>\n",
       "      <td>12.00</td>\n",
       "      <td>11.60</td>\n",
       "      <td>4.4375</td>\n",
       "      <td>36.80</td>\n",
       "      <td>17.7619</td>\n",
       "      <td>13.7584</td>\n",
       "      <td>81.00</td>\n",
       "      <td>2.9393</td>\n",
       "      <td>10.0700</td>\n",
       "      <td>20.15</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4995</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>23.8600</td>\n",
       "      <td>35.98</td>\n",
       "      <td>1.3200</td>\n",
       "      <td>40.6400</td>\n",
       "      <td>NaN</td>\n",
       "      <td>43.3600</td>\n",
       "      <td>NaN</td>\n",
       "      <td>58.32</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4996</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>23.8500</td>\n",
       "      <td>35.70</td>\n",
       "      <td>1.3500</td>\n",
       "      <td>40.5100</td>\n",
       "      <td>NaN</td>\n",
       "      <td>43.5800</td>\n",
       "      <td>NaN</td>\n",
       "      <td>58.06</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4997</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>23.2000</td>\n",
       "      <td>35.94</td>\n",
       "      <td>1.3300</td>\n",
       "      <td>37.2800</td>\n",
       "      <td>NaN</td>\n",
       "      <td>44.0000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>58.02</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4998</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>23.7000</td>\n",
       "      <td>35.87</td>\n",
       "      <td>1.2810</td>\n",
       "      <td>40.2900</td>\n",
       "      <td>NaN</td>\n",
       "      <td>44.5900</td>\n",
       "      <td>NaN</td>\n",
       "      <td>58.02</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4999</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>23.9300</td>\n",
       "      <td>35.91</td>\n",
       "      <td>1.2500</td>\n",
       "      <td>39.9400</td>\n",
       "      <td>NaN</td>\n",
       "      <td>45.1100</td>\n",
       "      <td>NaN</td>\n",
       "      <td>57.41</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5000 rows × 6373 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "         SIX NIHDQ    SSNT MOG-A   EPOW   JILL  FSNB    AEHL     RXRX  \\\n",
       "0     2.1775   NaN  4.3000   NaN  2.230  63.65  9.80  23.701  30.0000   \n",
       "1     2.1675   NaN  4.2700   NaN  3.050  64.80  9.80  23.100  28.6774   \n",
       "2     2.2000   NaN  4.0000   NaN  2.590  66.80  9.80  24.200  27.3200   \n",
       "3     2.0575   NaN  4.2237   NaN  2.300  66.35  9.85  24.800  29.5000   \n",
       "4     2.0000   NaN  4.1000   NaN  2.181  66.90  9.80  24.500  33.6400   \n",
       "...      ...   ...     ...   ...    ...    ...   ...     ...      ...   \n",
       "4995     NaN   NaN     NaN   NaN    NaN    NaN   NaN     NaN      NaN   \n",
       "4996     NaN   NaN     NaN   NaN    NaN    NaN   NaN     NaN      NaN   \n",
       "4997     NaN   NaN     NaN   NaN    NaN    NaN   NaN     NaN      NaN   \n",
       "4998     NaN   NaN     NaN   NaN    NaN    NaN   NaN     NaN      NaN   \n",
       "4999     NaN   NaN     NaN   NaN    NaN    NaN   NaN     NaN      NaN   \n",
       "\n",
       "         PLAO  ...   MPTI   ABST     SHEN     VZ      ENZ     EBAY    WORX  \\\n",
       "0     10.0300  ...  13.30  11.00   4.4000  35.10  17.1429  13.5438   48.00   \n",
       "1     10.0301  ...  16.72  11.80   4.3167  35.50  17.2381  13.3228   60.45   \n",
       "2     10.1000  ...  14.04  11.73   4.3500  36.25  17.5238  13.5817  125.25   \n",
       "3     10.0800  ...  11.94  11.35   4.4084  36.45  17.6190  13.6953  100.95   \n",
       "4     10.0200  ...  12.00  11.60   4.4375  36.80  17.7619  13.7584   81.00   \n",
       "...       ...  ...    ...    ...      ...    ...      ...      ...     ...   \n",
       "4995      NaN  ...    NaN    NaN  23.8600  35.98   1.3200  40.6400     NaN   \n",
       "4996      NaN  ...    NaN    NaN  23.8500  35.70   1.3500  40.5100     NaN   \n",
       "4997      NaN  ...    NaN    NaN  23.2000  35.94   1.3300  37.2800     NaN   \n",
       "4998      NaN  ...    NaN    NaN  23.7000  35.87   1.2810  40.2900     NaN   \n",
       "4999      NaN  ...    NaN    NaN  23.9300  35.91   1.2500  39.9400     NaN   \n",
       "\n",
       "        RUSHB    TWLVU    SXT  \n",
       "0      2.8652  10.0200  19.87  \n",
       "1      2.8741  10.0662  20.06  \n",
       "2      2.8385  10.0700  20.34  \n",
       "3      2.9926  10.0600  20.08  \n",
       "4      2.9393  10.0700  20.15  \n",
       "...       ...      ...    ...  \n",
       "4995  43.3600      NaN  58.32  \n",
       "4996  43.5800      NaN  58.06  \n",
       "4997  44.0000      NaN  58.02  \n",
       "4998  44.5900      NaN  58.02  \n",
       "4999  45.1100      NaN  57.41  \n",
       "\n",
       "[5000 rows x 6373 columns]"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_dict['open']"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "py38",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
