Install Python Library Mac
Installing Python 2 on Mac OS X. Setuptools enables you to download and install any compliant Python software over a network (usually the Internet) with a single command (easyinstall). It also enables you to add this network installation capability to your own Python software with very little work. To install the library without full voice support, you can just run the following command: # Linux/macOS python3 -m pip install -U discord.py # Windows py -3 -m pip install -U discord.py Otherwise to get voice support you should run the following command. Then use this command to install pip. C:Python27python get-pip.py. After that you can install any package using pip. I hope after following all these steps you’ll be able to download and install python libraries. For answering the question “How to Install Python library on windows”, I. Installing Python 3 on Mac OS X. Let’s install a real version of Python. Before installing Python, you’ll need to install GCC. GCC can be obtained by downloading Xcode, the smaller Command Line Tools (must have an Apple account) or the even smaller OSX-GCC-Installer package.
Welcome to the pythonnet troubleshooting wiki on Windows, Linux, and OSX!
If you get errors first things to check
Pythonnet consists of 2 DLLs: clr.pyd (clr.so or clr.dylib on Linux and OSX) and Python.Runtime.dll, first DLL is used to embed .NET in CPython with import clr statement and second DLL is used to embed CPython in .NET.
From PYPI
pip install pythonnet [--pre] -U (--pre gets the latest development build uploaded to PyPI)
Cant open picture library on mac. Apr 21, 2015 I successfully migrated from iPhoto library to this new Photos Library in April.17th, and everything seems okay except for some minor bugs. But from yesterday on, I started Photos and got this message 'Can't open Photos Library, try another.' If I try reading iPhoto or Aperture Library.
Built from master branch on github
Note that you need to have pip, wheel, setuptools installed. Also Windows SDK or Visual Studio (at least free version) need to be installed, since build process locates and uses msbuild.exe and mt.exe.
RGiesecke.DllExport from Unmanaged Exports does not support non-English ILdasm generated IL file. You can inspect RGiesecke.DllExport with ILSPY to fix it. Find and change '// Code' to you system language it in RGiesecke.DllExport.Parsing.Actions.DeleteExportAttributeParserAction.Execute:
Alternative solution is just to change system language to English before building clrmodule project.
1. Build in Visual Studio
The correct set of compilation symbols are selected with UCS2 (UCS4 for Mono), x86 or x64 build of CPython and Python version flag (PYTHON2.PYTHON3, PYTHON27.PYTHON36). Visual Studio provides Release/Debug, Mono/Windows, Python 2/3, x86/x64 configurations from solution, but PYTHON34.PYTHON36 flags need to be set manually in the properties of the projects Python.Runtime.csproj and clrmodule.csproj.
Copy clr.pyd and Python.Runtime.DLL to PYTHONFOLDERLibsite-packages or include their location path to search paths
2. Build and install from command-line
If you have Visual Studio installed, run Developer Command Prompt for VS as it has all the development paths set up. Otherwise you may experience RuntimeError: mt.exe could not be found when trying to install via pip.
If GIT is installed, execute:pip install git+https://github.com/pythonnet/pythonnet -U --force
Note that due to this issue --egg option is required temporarily:
or from local pythonnet source directory:python.exe setup.py bdist_wheelat runtime or with environment variables.
And install this wheel:
pip install --no-index --find-links=.dist pythonnet
Note that pip install wheel is requirement for building wheels.
Mac java ld_library_path. To install on Linux some dependencies are required such as:
- Mono-complete or Mono-devel (https://www.mono-project.com/download/stable/#download-lin), at least version 4.8
- clang (
sudo apt-get install clang) - glib (
sudo apt-get install libglib2.0-dev) - python-dev
Installed CPython is reachable by %PATH% or %PYTHONHOME% environment variables.
Pythonnet relies DLR and Hashset only added since CLR 4.0.
No left-over pythonnet assemblies in CPython folders (such as site-packages) or in GAC for CLR 2/4.
Make sure that all 3 WinForms demos are showing without errors:
helloform.pysplitter.pywordpad.py
nPython.exe shows an example of embedding CPython runtime in C# application using pythonnet.
Make sure that all Python tests are passing locally by running these commands:pip install pytestpython -m pytest.
Note that Python.Test.dll needs to be copied to PYTHONFOLDERLibsite-packages.
You can also run NUnit tests for embedding CPython in .NET using Python.EmbeddingTest.dll.
clr.AddReference('Assembly_Name') works by looking at 'Assembly_Name' without '.DLL'
Add path of .NET assembly 'Assembly_Name' to sys.path before using it from Python.
import Namespace_In_CLR works by importing the .NET namespace 'Namespace_In_CLR' in assembly 'Assembly_Name', which can be different!
System.BadImageFormatException: 'Could not load file or assembly 'Python.Runtime..' - mismatch of architecture (x86, x64) between Python and .NET.
'Unable to load DLL pythonXX': CPython is not installed, or not registered in %PATH% and %PYTHONHOME% environment variables. Alternatively set PythonEngine.PythonHome property before initializing Python runtime. More details in these issues:
Report wrong result or exception and traceback
Report minimal reproducible exception or wrong result
The versions and x86/x64 architecture of your Python, .NET/Mono, and OS.
When using .NET DLLs from pythonnet, analyze assembly binding errors using fuslogvw.exe.
When not sure about namespaces in the DLL, then use ILSPY for this purpose.
Check stackoverflow, mailing list archive, and past github issues:
Please review these issues with common pitfalls on Mac OSX:
There are currently (2017-11-20) two options for installing mono on OSX:
- Xamarin Latest Mono Mac Package which can also be install using Homebrew-Cask, just search for
mono-mdk, or read the Caskroom docs

Installation instructions for Homebrew mono formula:
brew install pkg-configbrew install glib --universalbrew install mono- Set
PKG_CONFIG_PATH=/Library/Frameworks/Mono.framework/Versions/?.?.?/lib/pkgconfig - Manually add a symbolic link to the respective mono folder:
/usr/local/your_python_path_here/lib
└─ $ ln -s /Library/Frameworks/Mono.framework/Versions/Current/lib/mono
export DYLD_LIBRARY_PATH=/Library/Frameworks/Mono.framework/Versions/Current/libUSE_OSX_FRAMEWORKS=0 ARCHFLAGS='-arch x86_64' pip install git+https://github.com/pythonnet/pythonnet
Installation instructions for Homebrew-Cask mono-mdk:
You may need to tap the caskroom first.
To build PythonNET for High Sierra, the latest master branch of PythonNet is required.
Find where mono-2.pc is on your Mac.
Use the location of mono-2.pc to replace {mono version} to build the Python wheel.
Install the {pythonnet version} for your {cpython version} and {mac version} found in the dist folder:
Note: The --user option is only required if installing into OSX system Python. Omit if using virtual or conda environment!
Important
If you are using a Python from any current python.orgPython installer for macOS (3.8.0+, 3.7.2+, 3.6.8, or 2.7.16+),no further action is needed to use IDLE or tkinter.A built-in version of Tcl/Tk 8.6 will be used.
If you are using macOS 10.6 or later, the Apple-suppliedTcl/Tk 8.5 has serious bugs that can cause application crashes.If you wish to use IDLE or Tkinter, do not use the Apple-suppliedPythons. Instead, install and use a newer version of Pythonfrom python.org or a third-party distributor that supplies orlinks with a newer version of Tcl/Tk.
Python's integrated development environment,IDLE, and thetkinter GUI toolkitit uses, depend on the Tk GUI toolkit which isnot part of Python itself. For best results, it is important that theproper release of Tcl/Tk is installed on your machine.For recent Python installers for macOS downloadable from this website,here is a summary of current recommendations followed by more detailedinformation.
| PythonRelease | InstallerVariant | macOSRelease | RecommendedTcl/Tk | AlternateTcl/Tk | NotRecommended |
|---|---|---|---|---|---|
| 3.8.2,3.7.7,2.7.17 | all | 10.6 to10.15 | built-in8.6.8 |
There are currently three major variants of Tk in common use on macOS:
- Aqua Cocoa Tk
- A newer native implementation availableas a universal 64-bit and 32-bit binary. This variant is the standard nativemacOS variant in Tk 8.6 and as of Tk 8.5.13. Aqua Cocoa support wasbackported to Tk 8.5 (prior to 8.5.13) and released by Apple starting with macOS 10.6and by ActiveState starting with their 8.5.9.1 release.
- Aqua Carbon Tk
- Because it is implemented with older macOS Carbon interfaces, it isonly available as a 32-bit binary (usually for Intel and PowerPCprocessors). Aqua Carbon Tk 8.4 is included with macOS releases 10.4through 10.14 and is also available from ActiveState. Aqua Carbon variantsof Tk 8.5 had been available as an ActiveState Community Download priorto ActiveTcl 8.5.9. As of 8.5.13, the Tk project no longer supportsCarbon builds of Tk 8.5. 32-bit-only Python installers downloadablefrom this website for older Python releases were linked with Aqua CarbonTk 8.4.
- X11 Tk
- The traditional platform-independent UNIX Tk implementation whichrequires an X11 server, such as the Apple X11.app available as anoptional component in older macOS releases or from third-partydistributors. 64-bit and32-bit binaries can be built. While the Python installers downloadablefrom this website do not support X11 Tk, other distributors ofPython for macOS may do so.
built-in 8.6.8
As of Python 3.7.0, 3.6.8, and 2.7.16, all current Python installers for macOSdownloadable from python.org supplytheir own private copies of Tcl/Tk 8.6.8. They do not look for or use anythird-party or system copies of Tcl/Tk. This is an Aqua Cocoa Tk.
ActiveTcl 8.5.18.0
ActiveState provides binary distributions of Tcl/Tk which are upward compatiblewith and generally more up-to-date than those provided by Apple in macOSreleases. This version of Tcl/Tk includes fixes for some critical problemsthat you may encounter using tkinter or IDLE (see Apple 8.5.9 below).You can download an installer for this release fromthe ActiveState web site.Note that ActiveState Community Edition binaries are not open source andare covered by an ActiveState license. You should read the licensebefore downloading to verify that your usage complies with its terms of use.As of Python 3.7.0, 3.6.8, and 2.7.16, no current Python installers for macOSdownloadable from python.org make use of this or any other external versionof Tcl/Tk.
This is an Aqua Cocoa Tk.
Install Python Library Macos
Apple 8.5.9
This release is included in macOS 10.7 through at least macOS 10.14.As of this writing,there are at least two known issues with Tk 8.5.9 thatare present in Apple 8.5.9 Tk but fixed in more recent upstream 8.5 releases.The more serious problem is an immediate crash in Tkwhen entering a composition character, like Option-u on a US keyboard.(This problem is documented asTk bug 2907388.)There is also the more general problem of input manager support for compositecharacters(Tk bug 3205153)which has also been fixed in more recent Tcl/Tk 8.5 releases.You can avoid these problems by using a current python.org installeror by using a third-partydistribution of Python that does not use Apple 8.5.9 Tk.This is an Aqua Cocoa Tk.
Apple 8.5.7
This release is included in macOS 10.6. IDLE is known to hang or crashwhen used with the Apple 8.5.7 included in all versions of macOS 10.6.x.Because of this,we strongly recommend that you do not attempt to use Tkinter or IDLE withthe Apple-supplied Python 2.6.1 in 10.6. Instead, install a newer version ofPython that supports a newer version of Tk.This is an Aqua Cocoa Tk.
Note
While Tcl and Tk areseparate frameworks and libraries, they are closely related and arenormally installed or updated simultaneously. You should notattempt to mix-and-match Tcl and Tk versions. References toa specific version of Tk assume the corresponding version ofTcl is installed as well.
The Python for macOS installers downloaded from this website dynamicallylink at runtime to Tcl/Tk macOS frameworks. The Tcl/Tk major version isdetermined when the installer is created and cannot be overridden.All current python.org installers for Python 3.7.x, 3.6.x,and 2.7.x link to their own built-in Tcl/Tk 8.6 frameworks and do not useexternal Tcl/Tk frameworks so the rest of this section only applies tonon-current releases and, as such, no longer supported.
The Python 64-bit/32-bit macOS installers for Python 3.6.x andand 2.7.x dynamically link to Tcl/Tk 8.5 frameworks.The dynamically linking occurs when tkinter (Python 3)or Tkinter (Python 2) is first imported (specifically, the internal_tkinter C extension module). By default, the macOS dynamic linkerlooks first in /Library/Frameworks for Tcl and Tk frameworks withthe proper major version. This is the standard location for third-partyor built from source frameworks, including the ActiveTcl releases.If frameworks of the proper major version are not found there,the dynamic linker looks for the same version in/System/Library/Frameworks, the location for Apple-suppliedframeworks shipped with macOS. (Note, you should normally not modifyor delete files in /System/Library.)
As is common on macOS, the installed Pythons and the Tcl and Tkframeworks are built to run on multiple CPU architectures (universalbinaries) and across multiple macOS levels (minimum deploymenttarget). For Python to be able to dynamically link with a particularTcl and Tk version, the available architectures in the Tcl/Tk frameworksmust include the architecture that Python is running in and theirminimum deployment target should be no greater than that of Python.
Install Python Libraries For Machine Learning
- 2020-03-10 - updated for 3.8.2 and 3.7.7
- 2019-12-19 - updated for 3.8.1, 3.7.6, and 2.7.17
- 2019-10-15 - updated for 3.8.0, 3.7.5, and macOS 10.15
- 2019-07-08 - updated for 3.7.4; 3.6.x is now security-fix-only
- 2019-03-25 - updated for 3.7.3
- 2019-03-03 - updated for 2.7.16
- 2018-12-24 - updated for 3.7.2 and 3.6.8
- 2018-10-20 - updated for 3.7.1, 3.6.7, and macOS 10.14
- 2018-06-27 - updated for 3.7.0 and 3.6.6
- 2018-05-30 - updated for 3.7.0b5
- 2018-05-02 - updated for 3.7.0b4 and 2.7.15; removed 32-bit-only refs
- 2018-03-29 - updated for 3.7.0b3 and 3.6.5
- 2018-02-28 - updated for 3.7.0b2
- 2018-01-31 - updated for 3.7.0b1 and 3.6.4
- 2017-10-03 - updated for 3.6.3 and macOS 10.13
- 2017-09-16 - updated for 2.7.14; removed 3.5.x
- 2017-07-17 - updated for 3.6.2
- 2017-03-21 - updated for 3.6.1 and (belatedly) 3.5.3
- 2016-12-23 - updated for 3.6.0
- 2016-12-17 - updated for 2.7.13
- 2016-09-23 - updated for macOS 10.12
- 2016-07-31 - updated for 3.5.2 and 2.7.12; removed 3.4.x
- 2015-12-20 - updated for 3.4.4
- 2015-12-06 - updated for 3.5.1, 2.7.11, and macOS 10.11
- 2015-09-13 - updated for 3.5.0
- 2015-05-23 - updated for 2.7.10 and ActiveTcl 8.5.18.0
- 2015-02-23 - updated for 3.4.3
- 2014-12-10 - updated for 2.7.9 and ActiveTcl 8.5.17.0
- 2014-10-16 - updated for macOS 10.10
- 2014-10-06 - updated for 3.4.2 and ActiveTcl 8.5.16.0
- 2014-09-22 - updated for 3.4.2rc1
- 2014-07-01 - updated for 2.7.8
- 2014-06-01 - updated for 2.7.7; removed 2.7.6 and 3.3.5
- 2014-05-18 - updated for 3.4.1 and 2.7.7rc1
- 2014-03-16 - updated for 3.4.0 and 3.3.5
- 2014-02-10 - updated for 3.3.4 and 3.4.0rc1
- 2014-01-05 - updated for 3.4.0b2
- 2013-11-24 - clarify that the ActiveState website still refers to 8.5.15.0
- 2013-11-24 - removed built-in for 3.4.0b1, removed 3.3.2 and 2.7.5
- 2013-11-10 - ActiveTcl 8.5.15.1; removed built-in for 3.3.3rc2 and 2.7.6.
- 2013-10-27 - updated for 3.3.3rc1 and 2.7.6rc1 and their built-in 8.5.15.
- 2013-10-24 - updated for macOS 10.9 and ActiveTcl 8.5.15, removed 3.2.5.
- 2013-10-20 - updated for 3.4.0a4 and its built-in 8.5.15.
- 2013-09-29 - updated for 3.4.0a3
- 2013-09-09 - updated for 3.4.0a2 and its built-in 8.5.14.
- 2013-08-03 - updated for 3.4.0a1 and ActiveTcl 8.4.20
- 2013-05-18 - updated for ActiveTcl 8.5.14
- 2013-05-15 - updated for 3.3.2, 2.7.5, and 3.2.5
- 2013-04-06 - updated for 3.3.1, 2.7.4, and 3.2.4
- 2012-12-26 - updated for ActiveTcl 8.5.13 and Issue 15853 patch installer
- 2012-09-29 - updated for 3.3.0 final and reverted to ActiveTcl 8.5.11.1
- 2012-08-02 - updated for ActiveTcl 8.5.12
- 2012-07-28 - updated for macOS 10.8
- 2012-04-11 - updated for 3.2.3 final and 2.7.3 final
- 2012-03-18 - updated for 3.2.3rc2 and 2.7.3rc2
- 2012-03-04 - updated for ActiveTcl 8.5.11.1, 3.2.3rc1, 2.7.3rc1, removed 3.1.4
- 2011-11-12 - updated for ActiveTcl 8.5.11
- 2011-09-04 - updated for 3.2.2 final
- 2011-07-21 - updated for macOS 10.7 and ActiveTcl 8.5.10.1
- 2011-07-09 - updated for 3.2.1 final and ActiveTcl 8.5.10
- 2011-06-12 - updated for 2.7.2 final and 3.1.4 final
- 2011-05-30 - updated for 3.2.1rc, 2.7.2rc, and 3.1.4rc
- 2011-03-08 - add warnings and include details on how Python links with Tcl/Tk releases
- 2011-02-20 - updated for 3.2 final
- 2011-01-31 draft 1 - preliminary info for 3.2rc2
- 2011-01-14 draft 0