PyCharm 2018.3 Help

Move and Copy refactorings

Basics

The Move refactorings allow you to move classes, functions, modules, files, and directories within a project. So doing, PyCharm tracks these movements and automatically corrects all references to the moved symbols in the source code.

The following Move refactorings are available:

  • The Move File refactoring moves a file to another directory.

  • The Move Directory refactoring moves a directory to another directory.

  • The Move Module Members refactoring moves top-level symbols of a Python module.

  • The Make local function/method top-level refactoring converts a method or a local function to a top-level function and moves it to the specified file.

Moving a file or a directory to another directory

  1. Select the file or directory in the Project tool window.

  2. On the main menu, or on the context menu of the editor, choose Refactor | Move or press F6.

  3. In the To directory field, specify the folder to move the selected file or folder to. Choose an existing folder from the drop-down list or type the full path to the parent folder to be created.

  4. To have the references to the selected file or folder updated according to the refactoring result, select the Search for references checkbox.

Moving top-level symbols

To move a member:

  1. Place the caret at a top-level symbol, for example:

    py move module member

  2. On the main menu, or on the context menu of the editor, choose Refactor | Move or press F6. The dialog box Move Module Members opens:
    py move module member1

    Refer to the dialog reference for the detailed description of controls.

  3. In this dialog box, select the members to be moved, and specify the target file.

  4. Preview and apply the changes.

Moving function/method to the top-level

This refactoring moves local functions or methods to the top-level by converting references to instance attributes or variables from enclosing scopes to parameters and updating existing usages accordingly.

To move a function or a method to top-level:

  1. Place the caret at the local function or method name.

  2. On the main menu, or on the context menu of the editor, choose Refactor | Move or press F6.

  3. In the Make Method Top-Level dialog box that opens, specify the destination of move. You can type it manually, or click the browse button browseButton and locate the destination file in the Choose Destination File dialog.

  4. Click Refactor to perform the refactoring, or Preview, to shows the preview in the Find tool window. If satisfied with the preview results, confirm move by clicking Do Refactor.

Example

Before

After

import math class Solver(object): def __init__(self, a, b, c): self.a = a self.b = b self.c = c def demo(self): d = self.b ** 2 - 4 * self.a * self.c if d >= 0: disc = math.sqrt(d) root1 = (- self.b + disc) / (2 * self.a) root2 = (- self.b - disc) / (2 * self.a) print(root1, root2) return root1, root2 else: raise Exception Solver(2, 123, 0.025).demo()

import math class Solver(object): def __init__(self, a, b, c): self.a = a self.b = b self.c = c def demo(b, a, c): d = b ** 2 - 4 * a * c if d >= 0: disc = math.sqrt(d) root1 = (- b + disc) / (2 * a) root2 = (- b - disc) / (2 * a) print(root1, root2) return root1, root2 else: raise Exception s = Solver(2, 123, 0.025) demo(s.b, s.a, s.c)

Copy refactoring

The Copy refactoring lets you create a copy of a file or directory in a different or the same directory.

To perform the Copy refactoring:

  1. Select the item of interest in a tool window (e.g. the Project tool window). Alternatively, open the necessary class or file in the editor.

  2. Do one of the following:
    • Choose Refactor | Copy on the main menu or the context menu.

    • Press F5.

    • In the Project tool window, press and hold the Ctrl key, and drag the item to the target location.

  3. In the Copy dialog that opens, specify the name and location for the copy that you are creating, and click OK.

Last modified: 27 February 2019

See Also