Logo ROOT  
Reference Guide
 
Loading...
Searching...
No Matches
pyroot006_tcontext_context_manager.py
Go to the documentation of this file.
1## \file
2## \ingroup tutorial_pyroot
3## \notebook -nodraw
4## This tutorial demonstrates the usage of the TContext class as a Python context
5## manager. This functionality is related with how TFile works, so it is
6## suggested to also take a look at the pyroot005 tutorial.
7##
8## \macro_code
9## \macro_output
10##
11## \date March 2022
12## \author Vincenzo Eduardo Padulano CERN/UPV
13import os
14
15import ROOT
16from ROOT import TDirectory, TFile
17
18# Sometimes it is useful to have multiple open files at once. In such cases,
19# the current directory will always be the file that was open last.
20file_1 = TFile("pyroot006_file_1.root", "recreate")
21file_2 = TFile("pyroot006_file_2.root", "recreate")
22print("Current directory: '{}'.\n".format(ROOT.gDirectory.GetName()))
23# Changing directory into another file can be safely done through a TContext
24# context manager.
25with TDirectory.TContext(file_1):
26 # Inside the statement, the current directory is file_1
27 print("Current directory: '{}'.\n".format(ROOT.gDirectory.GetName()))
28 histo_1 = ROOT.TH1F("histo_1", "histo_1", 10, 0, 10)
29 file_1.WriteObject(histo_1, "my_histogram")
30
31# After the context, the current directory is restored back to file_2. Also, the
32# two files are kept open. This means that objects read, written or modified
33# inside the context are still available afterwards.
34print("Current directory: '{}'.\n".format(ROOT.gDirectory.GetName()))
35if file_1.IsOpen() and file_2.IsOpen():
36 print("'{}' and '{}' are open.\n".format(file_1.GetName(), file_2.GetName()))
37
38# TContext and TFile context managers can also be used in conjunction, allowing
39# for safely:
40# - Opening a file, creating, modifying, writing and reading objects in it.
41# - Closing the file, storing it on disk.
42# - Restoring the previous value of gDirectory to the latest file opened before
43# this context, rather than to the global ROOT.gROOT
44# Remember that the TContext must be initialized before the TFile, otherwise the
45# current directory would already be set to the file opened for this context.
46with TDirectory.TContext(), TFile("pyroot006_file_3.root", "recreate") as f:
47 print("Current directory: '{}'.\n".format(ROOT.gDirectory.GetName()))
48 histo_2 = ROOT.TH1F("histo_2", "histo_2", 10, 0, 10)
49 f.WriteObject(histo_2, "another_histogram")
50
51print("Current directory: '{}'.\n".format(ROOT.gDirectory.GetName()))
52
53# Cleanup the files created for this tutorial
54file_1.Close();
55file_2.Close();
56for i in range(1, 4):
57 os.remove("pyroot006_file_{}.root".format(i))
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char Pixmap_t Pixmap_t PictureAttributes_t attr const char char ret_data h unsigned char height h Atom_t Int_t ULong_t ULong_t unsigned char prop_list Atom_t Atom_t Atom_t Time_t format
TDirectory::TContext keeps track and restore the current directory.
Definition TDirectory.h:89
A ROOT file is an on-disk file, usually with extension .root, that stores objects in a file-system-li...
Definition TFile.h:53