Difference between revisions of "Python"

From FreeCAD Documentation
Jump to: navigation, search
(<translate>)
(Marked this version for translation)
Line 1: Line 1:
 
<languages/>
 
<languages/>
 
<translate>
 
<translate>
 +
<!--T:25-->
 
{{VeryImportantMessage|(November 2018) FreeCAD was originally designed to work with Python 2. Many features work with Python 3, but some do not. Making FreeCAD fully support Python 3 is a work in process.}}
 
{{VeryImportantMessage|(November 2018) FreeCAD was originally designed to work with Python 2. Many features work with Python 3, but some do not. Making FreeCAD fully support Python 3 is a work in process.}}
  
== Description ==
+
== Description == <!--T:26-->
  
 +
<!--T:27-->
 
[https://www.python.org Python] is a general purpose, high level programming language that is very commonly used in large applications to automate some tasks by creating scripts or [[macros]].
 
[https://www.python.org Python] is a general purpose, high level programming language that is very commonly used in large applications to automate some tasks by creating scripts or [[macros]].
  
 +
<!--T:28-->
 
In FreeCAD, Python code can be used to create various elements programmatically, without needing to click on the graphical user interface. Additionally, many tools and workbenches of FreeCAD are programmed in Python.
 
In FreeCAD, Python code can be used to create various elements programmatically, without needing to click on the graphical user interface. Additionally, many tools and workbenches of FreeCAD are programmed in Python.
  
 +
<!--T:29-->
 
See [[Introduction to Python]] to learn about the Python programming language, and then [[Python scripting tutorial]] and [[FreeCAD Scripting Basics]] to start scripting in FreeCAD.
 
See [[Introduction to Python]] to learn about the Python programming language, and then [[Python scripting tutorial]] and [[FreeCAD Scripting Basics]] to start scripting in FreeCAD.
  
 +
<!--T:30-->
 
When writing Python code, it's advisable to follow [https://www.python.org/dev/peps/pep-0008/ PEP8: Style Guide for Python Code].
 
When writing Python code, it's advisable to follow [https://www.python.org/dev/peps/pep-0008/ PEP8: Style Guide for Python Code].
  
== Conventions ==
+
== Conventions == <!--T:31-->
 
In this documentation, some conventions for Python examples should be followed.
 
In this documentation, some conventions for Python examples should be followed.
  
 +
<!--T:32-->
 
This is a typical function signature
 
This is a typical function signature
 
</translate>
 
</translate>
Line 24: Line 30:
 
<translate>
 
<translate>
  
 +
<!--T:33-->
 
* Arguments with key-value pairs are optional, with the default value indicated in the signature. This means that the following calls are equivalent:
 
* Arguments with key-value pairs are optional, with the default value indicated in the signature. This means that the following calls are equivalent:
 
</translate>
 
</translate>
Line 36: Line 43:
  
 
<translate>
 
<translate>
 +
<!--T:34-->
 
: In this example the first argument doesn't have a default value so it should always be included.
 
: In this example the first argument doesn't have a default value so it should always be included.
  
 +
<!--T:35-->
 
* When the arguments are given with the explicit key, the optional arguments can be given in any order. This means that the following calls are equivalent:
 
* When the arguments are given with the explicit key, the optional arguments can be given in any order. This means that the following calls are equivalent:
 
</translate>
 
</translate>
Line 48: Line 57:
 
<translate>
 
<translate>
  
 +
<!--T:36-->
 
* Python's guidelines stress readability of code; in particular, parentheses should immediately follow the function name, and a space should follow a comma.
 
* Python's guidelines stress readability of code; in particular, parentheses should immediately follow the function name, and a space should follow a comma.
 
</translate>
 
</translate>
Line 59: Line 69:
 
<translate>
 
<translate>
  
 +
<!--T:37-->
 
* If code needs to be broken over several lines, this should be done at a comma inside brackets or parentheses; the second line should be aligned with the previous one.
 
* If code needs to be broken over several lines, this should be done at a comma inside brackets or parentheses; the second line should be aligned with the previous one.
 
</translate>
 
</translate>
Line 72: Line 83:
 
<translate>
 
<translate>
  
 +
<!--T:38-->
 
* Functions may return an object that can be used as the base of another drawing function.
 
* Functions may return an object that can be used as the base of another drawing function.
 
</translate>
 
</translate>
Line 80: Line 92:
 
<translate>
 
<translate>
  
== Imports ==
+
== Imports == <!--T:39-->
  
 +
<!--T:40-->
 
Python functions are stored in files called modules. Before using any function in that module, the module must be included in the document with the {{incode|import}} instruction.
 
Python functions are stored in files called modules. Before using any function in that module, the module must be included in the document with the {{incode|import}} instruction.
  
 +
<!--T:41-->
 
This creates prefixed functions, that is, {{incode|module.function()}}. This system prevents name clashes with functions that are named the same but that come from different modules.
 
This creates prefixed functions, that is, {{incode|module.function()}}. This system prevents name clashes with functions that are named the same but that come from different modules.
 
For example, the two functions {{incode|Arch.makeWindow()}} and {{incode|myModule.makeWindow()}} may coexist without problem.
 
For example, the two functions {{incode|Arch.makeWindow()}} and {{incode|myModule.makeWindow()}} may coexist without problem.
  
 +
<!--T:42-->
 
Full examples should include the necessary imports and the prefixed functions.
 
Full examples should include the necessary imports and the prefixed functions.
  
Line 113: Line 128:
  
 
<translate>
 
<translate>
 +
<!--T:43-->
 
[[Category:API Documentation]]
 
[[Category:API Documentation]]
 
[[Category:Developer Documentation]]
 
[[Category:Developer Documentation]]

Revision as of 19:37, 8 January 2019

Other languages:
Deutsch • ‎English • ‎français • ‎italiano • ‎română • ‎русский • ‎Türkçe
(November 2018) FreeCAD was originally designed to work with Python 2. Many features work with Python 3, but some do not. Making FreeCAD fully support Python 3 is a work in process.


Description

Python is a general purpose, high level programming language that is very commonly used in large applications to automate some tasks by creating scripts or macros.

In FreeCAD, Python code can be used to create various elements programmatically, without needing to click on the graphical user interface. Additionally, many tools and workbenches of FreeCAD are programmed in Python.

See Introduction to Python to learn about the Python programming language, and then Python scripting tutorial and FreeCAD Scripting Basics to start scripting in FreeCAD.

When writing Python code, it's advisable to follow PEP8: Style Guide for Python Code.

Conventions

In this documentation, some conventions for Python examples should be followed.

This is a typical function signature

Wire = makeWire(pointslist, closed=False, placement=None, face=None, support=None)
  • Arguments with key-value pairs are optional, with the default value indicated in the signature. This means that the following calls are equivalent:
Wire = makeWire(pointslist, False, None, None, None)
Wire = makeWire(pointslist, False, None, None)
Wire = makeWire(pointslist, False, None)
Wire = makeWire(pointslist, False)
Wire = makeWire(pointslist)
In this example the first argument doesn't have a default value so it should always be included.
  • When the arguments are given with the explicit key, the optional arguments can be given in any order. This means that the following calls are equivalent:
Wire = makeWire(pointslist, closed=False, placement=None, face=None)
Wire = makeWire(pointslist, closed=False, face=None, placement=None)
Wire = makeWire(pointslist, placement=None, closed=False, face=None)
Wire = makeWire(pointslist, support=None, closed=False, placement=None, face=None)
  • Python's guidelines stress readability of code; in particular, parentheses should immediately follow the function name, and a space should follow a comma.
p1 = Vector(0, 0, 0)
p2 = Vector(1, 1, 0)
p3 = Vector(2, 0, 0)
Wire = makeWire([p1, p2, p3], closed=True)
  • If code needs to be broken over several lines, this should be done at a comma inside brackets or parentheses; the second line should be aligned with the previous one.
a_list = [1, 2, 3,
          2, 4, 5]

Wire = makeWire(pointslist,
                False, None,
                None, None)
  • Functions may return an object that can be used as the base of another drawing function.
Wire = makeWire(pointslist, closed=True, face=True)
Window = makeWindow(Wire, name="Big window")

Imports

Python functions are stored in files called modules. Before using any function in that module, the module must be included in the document with the import instruction.

This creates prefixed functions, that is, module.function(). This system prevents name clashes with functions that are named the same but that come from different modules. For example, the two functions Arch.makeWindow() and myModule.makeWindow() may coexist without problem.

Full examples should include the necessary imports and the prefixed functions.

import FreeCAD, Draft

p1 = FreeCAD.Vector(0, 0, 0)
p2 = FreeCAD.Vector(1, 1, 0)
p3 = FreeCAD.Vector(2, 0, 0)
Wire = Draft.makeWire([p1, p2, p3], closed=True)
import FreeCAD, Draft, Arch

p1 = FreeCAD.Vector(0, 0, 0)
p2 = FreeCAD.Vector(1, 0, 0)
p3 = FreeCAD.Vector(1, 1, 0)
p4 = FreeCAD.Vector(0, 2, 0)
pointslist = [p1, p2, p3, p4]

Wire = Draft.makeWire(pointslist, closed=True, face=True)
Structure = Arch.makeStructure(Wire, name="Big pillar")