- Notifications
You must be signed in to change notification settings - Fork112
⚙️ Python API / wrapper for tmux
License
tmux-python/libtmux
Folders and files
| Name | Name | Last commit message | Last commit date | |
|---|---|---|---|---|
Repository files navigation
libtmux is atyped Python library that provides a wrapper for interacting programmatically with tmux, a terminal multiplexer. You can use it to manage tmux servers,sessions, windows, and panes. Additionally,libtmux powerstmuxp, a tmux workspace manager.
- Intuitive API: Control tmux servers, sessions, windows, and panes with a clean, object-oriented interface
- Complete Automation: Create and manage complex tmux environments programmatically
- Type Annotations: Full typing support for modern Python development
- Pytest Plugin: Built-in testing tools for tmux automation
- Context Managers: Safe session and window management with Python's context protocol
- Robust Architecture: Built on tmux's native concepts of targets and formats
libtmux builds upon tmux'starget andformats tocreate an object mapping to traverse, inspect and interact with livetmux sessions.
View thedocumentation,API information andarchitectural details.
- Development Environment Automation: Set up consistent workspaces across projects
- CI/CD Systems: Create isolated environments for testing and deployment
- System Monitoring: Build interactive dashboards for server administration
- Remote Pair Programming: Facilitate collaborative development sessions
- Data Science Workflows: Manage complex data processing pipelines
- Education and Demonstrations: Create multi-window learning environments
For more detailed examples, see ouruse cases documentation.
$pip install --user libtmuxSession namefoo, window namebar
$tmux new-session -s foo -n bar$pythonUseptpython,ipython, etc. for a nice shell with autocompletions:
$pip install --user ptpython$ptpythonConnect to a live tmux session:
>>>importlibtmux>>>svr=libtmux.Server()>>>svrServer(socket_path=/tmp/tmux-.../default)
Tip: You can also usetmuxp'stmuxp shell to drop straight into yourcurrent tmux server / session / window pane.
Run any tmux command, respective of context:
Honors tmux socket name and path:
>>>server=Server(socket_name='libtmux_doctest')>>>server.cmd('display-message','hello world')<libtmux...>
New session:
>>>server.cmd('new-session','-d','-P','-F#{session_id}').stdout[0]'$2'
>>>session.cmd('new-window','-P').stdout[0]'libtmux...:2.0'
From raw command output, to a richWindow object (in practice and as shownlater, you'd useSession.new_window()):
>>>Window.from_window_id(window_id=session.cmd('new-window','-P','-F#{window_id}').stdout[0],server=session.server)Window(@22:...,Session($1libtmux_...))
Create a pane from a window:
>>>window.cmd('split-window','-P','-F#{pane_id}').stdout[0]'%2'
Raw output directly to aPane:
>>>Pane.from_pane_id(pane_id=window.cmd('split-window','-P','-F#{pane_id}').stdout[0],server=window.server)Pane(%...Window(@11:...,Session($1libtmux_...)))
List sessions:
>>>server.sessions[Session($1 ...),Session($0 ...)]
Filter sessions by attribute:
>>>server.sessions.filter(history_limit='2000')[Session($1 ...),Session($0 ...)]
Direct lookup:
>>>server.sessions.get(session_id="$1")Session($1 ...)
Filter sessions:
>>>server.sessions[0].rename_session('foo')Session($1foo)>>>server.sessions.filter(session_name="foo")[Session($1foo)]>>>server.sessions.get(session_name="foo")Session($1foo)
Control your session:
>>>sessionSession($1 ...)>>>session.rename_session('my-session')Session($1my-session)
Create new window in the background (don't switch to it):
>>>bg_window=session.new_window(attach=False,window_name="ha in the bg")>>>bg_windowWindow(@...2:hainthebg,Session($1 ...))# Session can search the window>>>session.windows.filter(window_name__startswith="ha")[Window(@...2:hainthebg,Session($1 ...))]# Directly>>>session.windows.get(window_name__startswith="ha")Window(@...2:hainthebg,Session($1 ...))# Clean up>>>bg_window.kill()
Close window:
>>>w=session.active_window>>>w.kill()
Grab remaining tmux window:
>>>window=session.active_window>>>window.split(attach=False)Pane(%2Window(@11:...Session($1 ...)))
Rename window:
>>>window.rename_window('libtmuxower')Window(@11:libtmuxower,Session($1 ...))
Split window (create a new pane):
>>>pane=window.split()>>>pane=window.split(attach=False)>>>pane.select()Pane(%3Window(@11:...,Session($1 ...)))>>>window=session.new_window(attach=False,window_name="test")>>>windowWindow(@22:test,Session($1 ...))>>>pane=window.split(attach=False)>>>panePane(%5Window(@22:test,Session($1 ...)))
Type inside the pane (send key strokes):
>>>pane.send_keys('echo hey send now')>>>pane.send_keys('echo hey',enter=False)>>>pane.enter()Pane(%1 ...)
Grab the output of pane:
>>>pane.clear()# clear the panePane(%1 ...)>>>pane.send_keys("cowsay 'hello'",enter=True)>>>print('\n'.join(pane.cmd('capture-pane','-p').stdout))# doctest: +SKIP$cowsay'hello'_______<hello>------- \^__^ \ (oo)\_______ (__)\ )\/\||----w|||||...
Traverse and navigate:
>>>pane.windowWindow(@11:...,Session($1 ...))>>>pane.window.sessionSession($1 ...)
libtmux includes a pytest plugin that provides fixtures for testing tmux operations:
deftest_session_creation(session):"""Test creating a new window in the session."""window=session.new_window(window_name="test_window")assertwindow.window_name=="test_window"# Create a new panepane=window.split_window()assertlen(window.panes)==2# Send keys to the panepane.send_keys("echo 'Hello from test'")
Seepytest plugin documentation for more details.
libtmux supports a wide range of advanced use cases:
Safely manage sessions and windows with Python's context protocol:
withServer().new_session(session_name="my_session")assession:window=session.new_window(window_name="my_window")# Work with the window...# Session is properly cleaned up when context exits
Create complex window layouts and integrate with external systems:
session=server.new_session(session_name="dashboard")main=session.new_window(window_name="main")# Create a grid layout with 4 panestop_left=main.attached_panetop_right=top_left.split_window(vertical=True)bottom_left=top_left.split_window(vertical=False)bottom_right=top_right.split_window(vertical=False)# Configure each panetop_left.send_keys("htop",enter=True)top_right.send_keys("watch -n 1 df -h",enter=True)bottom_left.send_keys("tail -f /var/log/syslog",enter=True)bottom_right.send_keys("netstat -tunapl",enter=True)
Seeadvanced scripting documentation for more examples.
Unsupported / no security releases or bug fixes:
- Python 2.x: The backports branch is
v0.8.x.
Your donations fund development of new features, testing and support.Your money will go directly to maintenance and development of theproject. If you are an individual, feel free to give whatever feelsright for the value you get out of the project.
See donation options athttps://git-pull.com/support.html.
- tmux support: 1.8+
- python support: >= 3.9, pypy, pypy3
- Source:https://github.com/tmux-python/libtmux
- Docs:https://libtmux.git-pull.com
- API:https://libtmux.git-pull.com/api.html
- Changelog:https://libtmux.git-pull.com/history.html
- Issues:https://github.com/tmux-python/libtmux/issues
- Test Coverage:https://codecov.io/gh/tmux-python/libtmux
- pypi:https://pypi.python.org/pypi/libtmux
- Open Hub:https://www.openhub.net/p/libtmux-python
- Repology:https://repology.org/project/python:libtmux/versions
- License:MIT.
About
⚙️ Python API / wrapper for tmux
Topics
Resources
License
Contributing
Uh oh!
There was an error while loading.Please reload this page.
Stars
Watchers
Forks
Uh oh!
There was an error while loading.Please reload this page.