To allow Ren'Py to be scripted in python, each Ren'Py statement has equivalent Python code. This usually consists of a Python function, but may also consist of a code pattern that performs an action equivalent to the statement.
The Ren'Py say statement is equivalent to calling the character object as a function. The following code displays the same line twice:
e "Hello, world."
$ e("Hello, world.")
Displaying narration can be done the same way, by using the
narrator character. When calling a character, it's possible to
supply the keyword argument interact. When interact is false,
Ren'Py will display the character dialogue box, and will then
return before performing an interaction.
This equivalence of characters and function objects works in the other direction as well. It is possible to declare a python function, and then use that function in the place of a character object. For example, the following function uses a variable to choose between two characters.
define lucy_normal = Character("Lucy")
define lucy_evil = Character("Evil Lucy")
init python:
    def l(what, **kwargs):
        if lucy_is_evil:
            lucy_evil(what, **kwargs)
        else:
            lucy_normal(what, **kwargs)
label start:
    $ lucy_is_evil = False
    l "Usually, I feel quite normal."
    $ lucy_is_evil = True
    l "But sometimes, I get really mad!"
A function used in this way should either ignore unknown keyword arguments, or pass them to a character function. Doing this will allow the game to continue working if Ren'Py adds additional keyword arguments to character calls.
renpy.say(who, what, interact=True) linkThe equivalent of the say statement.
say() is used to create the speaking character.This function is rarely necessary, as the following three lines are equivalent.
e "Hello, world."
$ renpy.say(e, "Hello, world.")
$ e("Hello, world.")
The image, scene, show, and hide statements each have an equivalent python function.
renpy.get_at_list(name, layer=None) linkReturns the list of transforms being applied to the image with tag name on layer. Returns an empty list if no transofrms are being applied, or None if the image is not shown.
If layer is None, uses the default layer for the given tag.
renpy.hide(name, layer=None) linkHides an image from a layer. The python equivalent of the hide statement.
renpy.image(name, d) linkDefines an image. This function is the python equivalent of the image statement.
This function may only be run from inside an init block. It is an error to run this function once the game has started.
renpy.layer_at_list(at_list, layer='master') linkThe python equivalent of the show layer layer at at_list
statement.
renpy.scene(layer='master') linkRemoves all displayables from layer. This is equivalent to the scene statement, when the scene statement is not given an image to show.
A full scene statement is equivalent to a call to renpy.scene followed by a
call to renpy.show(). For example:
scene bg beach
is equivalent to:
$ renpy.scene()
$ renpy.show("bg beach")
renpy.show(name, at_list=, []layer='master', what=None, zorder=0, tag=None, behind=[]) linkShows an image on a layer. This is the programmatic equivalent of the show statement.
at property.onlayer property. If None, uses the default
layer associated with the tag.zorder property. If None, the
zorder is preserved if it exists, and is otherwise set to 0.as property.behind property.renpy.show_layer_at(at_list, layer='master') linkThe python equivalent of the show layer layer at at_list
statement.
The equivalent of the with statement is the renpy.with_statement function.
renpy.with_statement(trans, always=False) linkCauses a transition to occur. This is the python equivalent of the with statement.
This function returns true if the user chose to interrupt the transition, and false otherwise.
The equivalent of the jump statement is the renpy.jump function.
renpy.jump(label) linkCauses the current statement to end, and control to jump to the given label.
The equivalent of the call statement is the renpy.call function.
renpy.call(label, *args, **kwargs) linkCauses the current Ren'Py statement to terminate, and a jump to a label to occur. When the jump returns, control will be passed to the statement following the current statement.
renpy.return_statement() linkCauses Ren'Py to return from the current Ren'Py-level call.