Import/Export IFC - compiling IfcOpenShell/fr

Introduction
La recherche d'une copie de travail d'IfcOpenShell-python sous OSX/macOS pour importer/exporter des fichiers IFC a été si difficile que je partage ce tutoriel au cas où cela aiderait plus de gens. Mon système est OSX 10.11.6, 64 bits avec Python 2.7.11, cela pourrait fonctionner pour vous si vous avez également OSX car ils sont souvent 64 bits mais peuvent différer du mien. La procédure peut être très similaire si vous exécutez Linux ou Windows, mais elle présente probablement quelques différences.

Étapes
1. Téléchargez ou clonez le projet GitHub complet sur https://github.com/IfcOpenShell/IfcOpenShell (ce sera toujours la version la plus récente)

2. Depuis un terminal, accédez au dossier et lancez le script. Sous OSX, il est exécuté avec:

Il faudra entre 30 et 120 minutes pour tout compiler. Ce n'est pas la façon la plus intelligente de compiler IfcOpenShell mais ce simple script compilera toutes les dépendances, les versions de Python, etc.

3. Once it finishes (I don't remember now but it will be printed something like "Built IfcOpenShell..." and it will return to your prompt) you will have a new folder full of files and folders. From my personal experience, two weeks ago the nix "build-all.sh" script didn't finished successfully but after trying it yesterday with the newest updates it worked fine so I guess you might experience something similar in case the development goes further... So now you have everything you need but you have to do some manual work in order to get it working:

4. Open FreeCAD and open the Python console and Report view. Then write into the Python console the following:

You will get a looooong line with all the paths that FreeCAD reads. You may be able to install IfcOpenShell in any of them but I suggest you to place it inside one where you find a after a  or. In my case it was. (Note: you will find paths inside your app directory but I suggest you to not use them because then IfcOpenShell will only be available for this app)

5. Once located where you want/have to install it, go there with your file browser (Finder in OSX). That is, go inside folder

6. Open a new file browser window and navigate to your downloaded GitHub project: /IfcOpenShell/src/ifcopenshell-python/ and copy the full /ifcopenshell/ folder

7. Paste it inside /site-packages/ folder. Now you should have something like:

8. Now we have to pick to files inside the /build/ folder, they are:

but as we have compiled everything you will have to pick the one that matches with your FreeCAD Python version. Check it easily reading the first line inside your FreeCAD Python console view. In my case it was Python 2.7.11.

9. Now go let's copy the files inside the place it corresponds to your Python version. In my case it was:

10. Paste them inside

11. Check everything is in place:

(1) from GitHub project

(2) from /build/ folder

12. Close and reopen FreeCAD

Testing
Now that it is installed, let's check if everything works as expected:

12.1 in the Python console write:

if it doesn't throw any error it means it may be correctly installed

12.2 Go to Yorik's FreeCAD manual, navigate to the lower part of the page and download the following files to test:

12.3 Open, select the root "Building" object and export it setting the File type to "Industry Foundation Classes (*.ifc)". Press and if it works and it doesn't throw an error in the Report view then it's working.

12.4 Final test, import into a new file so open a new file and import that file... it will take a while.

13. Enjoy BIM with FreeCAD!

Final thoughts
My opinion is that FreeCAD itself should have precompiled versions of IfcOpenShell bundled with the distribution because building it by yourself is a total pain and average user won't do it (they don't know how to compile, manage GitHub, etc), but well, maybe in the future.

I hope it helps you.

Cheers

Links

 * Related forum thread discussion