Configuring code style
If certain coding guidelines exist in a company, one has to follow these guidelines when creating source code. PyCharm helps you maintain the required code style.
The IDE comes with two pre-defined schemes: the Project scheme and the Default scheme.
In the Project scheme, the settings that you configure apply only to your current project.
These settings are stored in the codeStyles folder under .idea and are shared through VCS together with the project.
The IDE creates the folder after you modify code style settings for your project.
In the Default scheme (IDE-level scheme), the settings that you configure apply to all existing projects that have the Default code style scheme selected.
These settings are stored in the codestyles folder under the PyCharm configuration directory and are not shared through VCS.
If you want to use the project code style scheme as your default scheme, you can copy it to the IDE level. The other way around is also possible: you can overwrite your current project settings with the settings from an IDE-level scheme and share them with other members of your team.
note
There can be only one Project code style scheme. On the IDE level, you can have multiple schemes. Several projects can refer to the same IDE-level code style scheme.
In PyCharm, code style settings are language-specific, so you need to configure them for every language that you use in your project separately. You can also copy the settings from one language and apply them to another language.
Press CtrlAlt0S to open settings and then select Editor | Code Style.
To configure a scheme for new projects, go to File | New Projects Setup | Settings for New Projects | Editor | Code Style.
Select the language for which you want to configure the code style.
Select the code style Scheme that you want to configure: the Project scheme or one of the IDE-level schemes.
tip
Click next to the Default scheme and select Duplicate to create a copy of the scheme.
Browse through the tabs and configure code style preferences.
Use the right section of the dialog to preview the changes. When you change a setting, one or several blinking areas appear in the preview area emphasizing the changes.
For most of the supported languages, you can copy code style settings from other languages or frameworks.
Press CtrlAlt0S to open settings and then select Editor | Code Style.
To configure a scheme for new projects, go to File | New Projects Setup | Settings for New Projects | Editor | Code Style in the main menu.
Select the language for which you want to configure the code style.
Select the code style Scheme that you want to modify: the Project scheme or one of the IDE-level schemes.
Click Set from in the upper-right corner.
The link is shown only if it is possible to apply code style settings from another language.
From the list that appears, select the language to copy the code style from.
note
Only applicable settings are copied from another language, other settings are left intact.
Press CtrlAlt0S to open settings and then select Editor | Code Style.
To configure a scheme for new projects, go to File | New Projects Setup | Settings for New Projects | Editor | Code Style in the main menu.
Select the code style Scheme that you want to copy: the Project scheme or one of the IDE-level schemes.
Click the icon and select one of the following options:
Copy to IDE (for the Project scheme): copy the selected scheme to the IDE level.
PyCharm saves the new code style with the specified name to the PyCharm home directory.
Copy to Project (for IDE-level schemes): overwrite your current project settings with the settings from the selected IDE-level profile.
Duplicate (for IDE-level schemes): create a copy of the selected IDE scheme on the same level.
In the Scheme field, type the name of the new scheme and press Enter to save the changes.
Out of the box, PyCharm allows you to import settings in the IntelliJ IDEA code style XML format.
Press CtrlAlt0S to open settings and then select Editor | Code Style.
Click and select Import Scheme.
In the dialog that opens, select the file with the settings and click Open.
Rename the scheme if necessary and select Current scheme to apply the settings from the scheme to your code.
You can export both project-level and IDE-level schemes in the IntelliJ IDEA code style XML or EditorConfig format (if the EditorConfig plugin is enabled).
Press CtrlAlt0S to open settings and then select Editor | Code Style.
Select the code style Scheme that you want to export: the Project scheme or one of the IDE-level schemes.
Click , select Export, select the necessary format, and select the directory to which you want to export your code style settings.
note
To use EditorConfig, make sure the EditorConfig plugin is enabled in the settings. Press CtrlAlt0S to open settings and then select Plugins. Click the Installed tab. In the search field, type EditorConfig. For more information about plugins, refer to Managing plugins.
PyCharm allows you to manage all code style settings for each individual set of files with EditorConfig support (enabled by default in the Settings dialog (CtrlAlt0S) ). All you need to do is place an .editorconfig file in the root directory containing the files whose code style you want to define. You can have as many .editorconfig files within a project as needed, so you can specify different styles for different modules.
All options from the .editorconfig file are applied to the directory where it resides as well as all of its sub-directories on top of the current project code style. If anything is not defined in .editorconfig
, it's taken from the project settings.
All options in the .editorconfig file are divided into the following categories:
Standard options such as
indent_size
,indent_style
, and so on. These options do not have any domain-specific prefixes.Generic IntelliJ options that have the
ij_
prefix and are applicable to all languages:ij_visual_guides
ij_formatter_off_tag
ij_formatter_on_tag
ij_formatter_tags_enabled
ij_wrap_on_typing
ij_continuation_indent_size
ij_smart_tabs
Common IntelliJ options supported by many (but not all) languages. They start with the
ij_any
prefix, for example,ij_any_brace_style
.IntelliJ language-specific options starting with the
ij_<lang>_
prefix where<lang>
is the language domain ID (normally a low-case language name), for example,ij_java_blank_lines_after_imports
.
note
The same options can be defined as a common option and a language-specific option, for example,
ij_<...>_brace_style
. Language-specific options have higher priority over common or generic options.
In the Project view, right-click a source directory containing the files whose code style you want to define and choose New | EditorConfig from the context menu.
Select the properties that you want to define so that PyCharm creates stubs for them, or leave all checkboxes empty to add the required properties manually.
To preview how changes to your code style settings will impact the actual source files, click in the gutter of the .editorconfig file and select a source file affected by it. The preview will open on the right.
You can make changes in the preview pane to try and test how your configuration changes are reflected without worrying about making unwanted changes to the source code: all these changes are discarded when you close the .editorconfig file.