Mac Install Python Libraries

03.04.2020by
Mac Install Python Libraries Rating: 4,4/5 6461 reviews
  1. Mac Install Python 2.7
  2. Mac Install Python Libraries Online
  3. Mac Install Python Libraries In Windows
  4. Install Python Libraries In Mac
  5. Mac Install Python Module

Next up, I’ll show you how you can install Python 3 using HomeBrew onto your macOS. This is my preferred way and it is just as simple as the method before but it will make your life a whole lot simpler, in the long run, using Python. Install Python 3 on Mac using HomeBrew. This method is dead-ass simple and a little fun. System files are protected by System Integrity Protection. You won't be able to follow these instructions to rm -rf random folders in /System without disabling SIP first. However, because the files are protected, you know the files haven't been modified.

In order to install the Cuemacro Python libraries, I would recommend following the instructions below. If you already have Python 3.5 installed,you can skip most of these steps. The below instructions assume that you have not installed Python at all and are assuming you have Windows.

At the end I also have comments related to installing finmarketpy, findatapy and chartpy on Linux and OS X.

In general, I would go in the order suggested here. Some components are optional (such as Bloomberg software).

Mac Install Python 2.7

Before installation of any specific Python libraries, we need to set up the core Python distribution and other programming tools,which will help you to write your own trading strategies and Python scripts for doing market analysis on top of the Cuemacro libraries.

  • Programming Tools

    • Anaconda 64 bit Python - download - Windows/Linux/Mac OS X
      • This is the most used Python distribution for data science
      • As well as installing the core Python libraries, it also installs many useful libraries like the SciPy stack, whichcontains NumPy, pandas etc. and many other useful libraries like matplotlib which are dependencies for the various Cuemacro libraries
      • Recommend installing latest version of Python 3.6 (by running in command line conda install python=3.6) as some of the multiprocessing libraries have issues with Python 3.6 at present when I've tried it
      • findatapy, chartpy and finmarketpy should be compatible with the dependencies in Anaconda (eg. version of pandas, numpy etc.)
    • Microsoft Visual Studio 2017 Community Edition - download or Visual C++ 2015 build tools - Windows
      • Makes sure to do a custom installation and tick Visual C++ in the Visual Studio 2017 installation
      • Alternatively, it is quicker to install Visual C++ 2017 build tools
        • You may need to add the following (or similar) to your Windows path C:Program Files (x86)Windows Kits8.1binx64
        • This should prevent the following compilation error where 'rl.exe' is not found
      • Some Python libraries need a C++ compiler in order to build (such as blpapi and arctic)
      • Often it is easier to install Python libraries using conda
      • Alternatively, if you don't want to compile the libraries yourself, you can sometimes find pre-compiledPython wheels for your platform
    • Git - https://git-scm.com/downloads - Windows/Linux/Mac OS X
      • Version control software
      • Makes it easier to maintain your own Python code
    • PyCharm Community Edition - download - Windows/Linux/Mac OS X
      • PyCharm is a relatively easy to use IDE for coding Python, with tools such as autocompletionand syntax highlighting
      • The Professional Edition also adds a few bells and whistles including a code profiler
      • I recommend running the 64 bit version, as I've the 32 bit version can run out memory particularly when buildingindices
      • There are many other alternative IDEs (and text editors) for Python, I recommend you also check out a few to see which you like most(or you just use a simple text editor like Notepad!)
        • Atom - hackable text editor, which also has addins for Python coding
        • PyDev - Python IDE written on top of Eclipse
        • Sublime - text editor
  • Data tools

    • MongoDB - download - Windows/Linux/Mac OS X
      • IOEngine class has a wrapper over arctic to use MongoDB (as well as HDF5 files if preferred)
      • Be sure to setup a database in MongoDB, if you wish to use it to store data later
    • Redis - Download - Windows/Linux/Mac OS X
      • IOEngine class has a wrapper to use Redis, as a high level cache
      • Redis is an in-memory database designed for short term volatile storage
      • findatapy uses it as a high level cache to speed up access to repeatedly used datasets
    • Bloomberg Terminal - download - Windows
      • Bloomberg provides a high quality data source
      • Note, you must be a subscriber for the software to function and to have a licence for the data
      • This also needs installation of your serial number
      • Bloomberg Terminal is only available for Windows
      • Bloomberg Server API is available for Windows/Linux/Mac OS X but runs under a different licence
  • Fonts

    • Open Sans - chartpy uses the open source Open Sans family of fonts as default for matplotlib
    • You can download these for free from Font Squirrel
    • Once downloaded you need to install them on your operating system
    • On Windows this involves copying the fonts to your Windows font folder (eg. C:WindowsFonts)
    • You need to delete matplotlib's font cache file, so it picks up the new font (eg. fontList.py3k.cache inC:UsersUser name.matplotlib
Libraries

Open up the Anaconda Command Prompt (accessible via the Start Menu) to run the various 'conda' and 'pip' commands to install thevarious Python libraries. The Cuemacro libraries will install most Python dependencies, but some need to be installed separately.

Location

Jan 05, 2020  How to set up iCloud Photo Library on your Mac Launch the Photos app on your Mac. Select the Photos menu in the upper left corner of your screen. Go to Preferences. Click on the iCloud tab. Check 'iCloud Photo Library.' This will begin uploading any and all images you have stored in the Photos. Library

Mac Install Python Libraries Online

Mac Install Python Libraries
  • Python libraries (open source)

    • arctic - pip install git+https://github.com/manahl/arctic.git
      • Wrapper for MongoDB (also installs pymongo)
      • Allows us to easily save and load pandas DataFrames in MongoDB
      • Also compresses data contents
    • blpapi - https://www.bloomberglabs.com/api/libraries/ (both C++ and Python libraries)
      • Interact with Bloomberg programmatically via Python to download historical and live data
      • Note that this requires a C++ compiler to build the Python library (at present Bloomberg doesn't have binaries for Python 3.5,hence you need to build them yourself)
      • Follow instructions at https://github.com/cuemacro/findatapy/blob/master/BLOOMBERG.md for all the steps necessary to install blpapi
    • Whilst Anaconda has most of the dependencies below and pip will install all additional ones needed by the Cuemacro Pythonlibraries it is possible to install them manually via pip, below is a list of the dependencies
      • all libraries
        • numpy - matrix algebra (Anaconda)
        • pandas - time series (Anaconda) - older versions of pandas could have issues due to deprecated methods - recommend 0.24.2
        • pytz - timezone management (Anaconda)
        • requests - accessing URLs (Anaconda)
        • mulitprocess - multitasking
        • multiprocessing_on_dill - multiprocessing on dill (similar to multiprocess, can select which library to use)
      • findatapy
        • pandas_datareader - accessing market data sources including Yahoo Finance (Anaconda)
        • quandl - accessing market data sources (Anaconda)
        • redis - Python wrapper to access Redis, in-memory database, like a hashtable (Anaconda Linux/Mac)
          • brew reinstall redis (Unix)
        • openpyxl - writing Excel spreadsheets to disk (Anaconda)
        • pyarrow - for caching
        • keyring - for storing passwords
        • arctic - wrapper on MongoDB (see below for installation)
        • blpapi - Python API for Bloomberg (see below for installation)
        • xlsxwriter - writing Excel files from Python (and reading) (Anaconda)
      • chartpy
        • bokeh - visualisation (Anaconda)
        • cufflinks - wrapper on plotly
        • matplotlib - visualisation (Anaconda)
        • plotly - visualisation (Anaconda)
        • vispy - visualisation with GPU acceleration
        • twython - Twitter library for Python
      • You can install all of these, and also chartpy, findatapy and finmarketpy by running the install_packages.bat file on Windows
  • Cuemacro Python libraries (open source)

    • Before we start, make sure we are familiar where your Anaconda site packages folder is (ie. where it will install your Python dependencies),as this will be where we need to edit the various configuation files described in this section.

      • Typically this is in folders like:
        • C:Anaconda3Libsite-packages
        • C:Program FilesAnacondaLibsite-packages
    • chartpy - pip install git+https://github.com/cuemacro/chartpy.git

      • Check constants file configuration chartpy/chartpy/util/chartconstants.py for
        • Adding your own API keys for Plotly, Twitter etc
        • Changing the default size of plots
        • Changing the default chart engine (eg. Plotly, Bokeh or Matplotlib)
      • Alternatively you can create chartcred.py class in the same folder to put your own API keys
      • This has the benefit of not being overwritten each time you upgrade the project
    • findatapy - pip install git+https://github.com/cuemacro/findatapy.git

      • Check constants file configuration findatapy/findatapy/util/dataconstants.py for
        • adding your own API keys for Quandl etc.
        • changing path of your local data source (change folder_time_series_data attribute)
        • changing path of the config folder if necessary (change config_root_folder attribute) so you can create your own customticker library (otherwise it will get overwritten each time you upgrade findatapy)
        • changing the ticker library (placed in findatapy/findatapy/conf/*.CSV files)
          • time_series_categories_fields.csv - define the categories of tickers and what fields they have
          • time_series_fields_list.csv - define aliases for vendor fields
          • time_series_tickers_list.csv - defines aliases for vendor tickers
          • There are already setup with a few FX tickers to act as an example
          • In addition, you can add your own CSV files to accompany time_series_tickers_list.csv (add to time_series_tickers_list attribute)
            • fx_vol_tickers.csv - samples of FX vol tickers
            • fx_forward_tickers.csv - samples of FX forward tickers
        • changing logging.conf
          • For customising how the project dumps logs to disk
      • Alternatively you can create datacred.py class in the same folder to put your own API keys and file folder settings.
      • This has the benefit of not being overwritten each time you upgrade the project.
      • Below we have a sample datacred.py class file, to be placed in the 'util' folder, any parameters set here, will overwritethose of dataconstants.py (note: for passwords if a datacred.py file is not created, it will usepasswords stored in your keyring and will prompt you the very first time it is run):

Mac Install Python Libraries In Windows

class DataCred(object):

You can then setup your own separate project in PyCharm to create your own trading strategies on top of it. I'd recommend creatinga private (or public) project on GitHub so you can use it for version control and backup on the cloud. BitBucket is an alternative onlinesite for hosting a Git server. It also possible to setup a Git server locally as well.

I have been able to install both chartpy and finmarketpy both Linux and Mac OS X, using the Anaconda distributionfor both platforms.

However, with findatapy, I would note that following:

Install Python Libraries In Mac

  • Bloomberg Terminal software is only available for windows, so Bloomberg Desktop API (DAPI) is not available for either Linux or Mac OS X,blpapi needs the Bloomberg Terminal software to communicate with

  • However, it should be possible to install Bloomberg Server API (SAPI) which allows blpapi to communicate with it, but you needa different Bloomberg server licence to run that

  • To install arctic on Mac OS X, read this useful thread, which gives suggestionson ways of solving issues when installing arctic on Mac OS X, in particular around the C compiler

  • Even if you cannot install blpapi and arctic, findatapy will still install and largely function, but you won't be ableto make Bloomberg calls or calls via arctic to MongoDB

Mac Install Python Module

  • To install findatapy into a conda environment separate from root, you will need to create that environment with pip (rather than create the environment and then install pip into it). So, do:

    This will ensure that pip installs any packages in this environment's site-packages folder rather than in the global site-packages folder. (This currently appears to be a known issue with conda - see https://github.com/ContinuumIO/anaconda-issues/issues/1429).

  • You can now activate the new conda environment and run pip install on findatapy:

    This will install findatapy into the conda environment's site-packages folder.

  • Above works fine for environments where you are planning to use findatapy. But for an environment if you plan to work on findatapy code itself, you might prefer to set it up a bit differently.This will keep code you are working on separate from the site-packages directory. So, instead of running pip install on findatapy, run conda install (or pip install since some of the packages don't appear to be available on conda) on each of the packages listed in findatapy's setup.py:

    I then separately clone the findatapy repository and add its location to my PYTHONPATH

  • If we wish to install an conda instance in our environment (which will install lots of libraries like pandas) we can instead run

Comments are closed.