How do I get the path and name of the python file that is currently executing?
Asked Answered
P

26

575

I have scripts calling other script files but I need to get the filepath of the file that is currently running within the process.

For example, let's say I have three files. Using execfile:

  • script_1.py calls script_2.py.
  • In turn, script_2.py calls script_3.py.

How can I get the file name and path of script_3.py, from code within script_3.py, without having to pass that information as arguments from script_2.py?

(Executing os.getcwd() returns the original starting script's filepath not the current file's.)

Poliomyelitis answered 8/9, 2008 at 19:41 Comment(5)
Related: Python __file__ attribute absolute or relative?Julee
related: How to properly determine current script directory?Conant
Does this answer your question? How do you properly determine the current script directory?Quebec
See also What exactly is current working directory?Conchitaconchobar
Related: How do I get the parent directory in Python?Outwardly
C
286

p1.py:

execfile("p2.py")

p2.py:

import inspect, os
print (inspect.getfile(inspect.currentframe())) # script filename (usually with path)
print (os.path.dirname(os.path.abspath(inspect.getfile(inspect.currentframe())))) # script directory
Crofton answered 8/9, 2008 at 23:2 Comment(11)
@David, when I do inspect.getfile(inspect.currentframe()), it gives me the full path of the file being processed. So I'm not sure what you mean, or under what conditions this would not give the "name and path".Epitasis
It does? Not for me, and several others by the look of it. The second line that has been added to the answer does provide the full path thoughRowdyish
BEWARE: This call does not give the same result with different environments. Consider accepting Usagi's answer below: https://mcmap.net/q/13307/-how-do-i-get-the-path-and-name-of-the-python-file-that-is-currently-executingHersey
@faraday: Could you provide an example? I've answered similar question using inspect.getabsfile() and it worked for all cases that I've tried.Conant
Is indeed @Usagi answer better?Obadias
nah user13993 nailed it far betterRileyrilievo
user13993 did indeed nail it. Should be os.path.realpath(__file__)Mountford
@Obadias user13933's method gives me the name of the caller not the called. This is right for the question asked.Servant
@osirisgothra: you do understand that __file__ doesn't work with execfile() that is explicitly mentioned in the question.Conant
While file is usually good enough, it wont work when you your program is running somewhere far away from file.Appleby
inspect.getfile() returns the __file__ attribute if passed a module object. inspect.currentframe() returns the module. Ergo, this is an expensive way of saying __file__.Bullpup
S
632
__file__

as others have said. You may also want to use os.path.realpath to eliminate symlinks:

import os

os.path.realpath(__file__)
Subcontract answered 23/12, 2009 at 20:33 Comment(6)
One needs to be careful with this approach because sometimes __file__ returns 'script_name.py', and other times 'script_name.pyc'. So output isn't stable.Mosasaur
But since we are only using the path of this file that's irrelevant.Howlan
this is weird: when running from command line "__file__" in quotes (as string) gives the dir from which cmd is run, but __file__ (without quotes gives the path to the source file ... why is thatPaleozoic
@Paleozoic there is no check performed on whether a filename string passed in exists, and since file paths are relative to the cwd, that is what the os.path.realpath function assumes the dir part of the path to be. os.path.dirname(os.path.realpath(__file__)) returns directory with the file. os.path.dirname(os.path.realpath("__file__")) returns cwd. os.path.dirname(os.path.realpath("here_be_dragons")) also returns cwd.Novanovaculite
"name 'file' is not defined"Graticule
I just wrote a big extension to this answer, here to obtain the: FULL_PATH_TO_SCRIPT, SCRIPT_DIRECTORY, FILENAME, FILENAME_NO_EXTENSION, FILENAME_EXTENSION, HOME_DIR_USER, and HOME_DIR_SCRIPT.Outwardly
C
286

p1.py:

execfile("p2.py")

p2.py:

import inspect, os
print (inspect.getfile(inspect.currentframe())) # script filename (usually with path)
print (os.path.dirname(os.path.abspath(inspect.getfile(inspect.currentframe())))) # script directory
Crofton answered 8/9, 2008 at 23:2 Comment(11)
@David, when I do inspect.getfile(inspect.currentframe()), it gives me the full path of the file being processed. So I'm not sure what you mean, or under what conditions this would not give the "name and path".Epitasis
It does? Not for me, and several others by the look of it. The second line that has been added to the answer does provide the full path thoughRowdyish
BEWARE: This call does not give the same result with different environments. Consider accepting Usagi's answer below: https://mcmap.net/q/13307/-how-do-i-get-the-path-and-name-of-the-python-file-that-is-currently-executingHersey
@faraday: Could you provide an example? I've answered similar question using inspect.getabsfile() and it worked for all cases that I've tried.Conant
Is indeed @Usagi answer better?Obadias
nah user13993 nailed it far betterRileyrilievo
user13993 did indeed nail it. Should be os.path.realpath(__file__)Mountford
@Obadias user13933's method gives me the name of the caller not the called. This is right for the question asked.Servant
@osirisgothra: you do understand that __file__ doesn't work with execfile() that is explicitly mentioned in the question.Conant
While file is usually good enough, it wont work when you your program is running somewhere far away from file.Appleby
inspect.getfile() returns the __file__ attribute if passed a module object. inspect.currentframe() returns the module. Ergo, this is an expensive way of saying __file__.Bullpup
P
105

Update 2018-11-28:

Here is a summary of experiments with Python 2 and 3. With

main.py - runs foo.py
foo.py - runs lib/bar.py
lib/bar.py - prints filepath expressions

| Python | Run statement       | Filepath expression                    |
|--------+---------------------+----------------------------------------|
|      2 | execfile            | os.path.abspath(inspect.stack()[0][1]) |
|      2 | from lib import bar | __file__                               |
|      3 | exec                | (wasn't able to obtain it)             |
|      3 | import lib.bar      | __file__                               |

For Python 2, it might be clearer to switch to packages so can use from lib import bar - just add empty __init__.py files to the two folders.

For Python 3, execfile doesn't exist - the nearest alternative is exec(open(<filename>).read()), though this affects the stack frames. It's simplest to just use import foo and import lib.bar - no __init__.py files needed.

See also Difference between import and execfile


Original Answer:

Here is an experiment based on the answers in this thread - with Python 2.7.10 on Windows.

The stack-based ones are the only ones that seem to give reliable results. The last two have the shortest syntax, i.e. -

print os.path.abspath(inspect.stack()[0][1])                   # C:\filepaths\lib\bar.py
print os.path.dirname(os.path.abspath(inspect.stack()[0][1]))  # C:\filepaths\lib

Here's to these being added to sys as functions! Credit to @Usagi and @pablog

Based on the following three files, and running main.py from its folder with python main.py (also tried execfiles with absolute paths and calling from a separate folder).

C:\filepaths\main.py: execfile('foo.py')
C:\filepaths\foo.py: execfile('lib/bar.py')
C:\filepaths\lib\bar.py:

import sys
import os
import inspect

print "Python " + sys.version
print

print __file__                                        # main.py
print sys.argv[0]                                     # main.py
print inspect.stack()[0][1]                           # lib/bar.py
print sys.path[0]                                     # C:\filepaths
print

print os.path.realpath(__file__)                      # C:\filepaths\main.py
print os.path.abspath(__file__)                       # C:\filepaths\main.py
print os.path.basename(__file__)                      # main.py
print os.path.basename(os.path.realpath(sys.argv[0])) # main.py
print

print sys.path[0]                                     # C:\filepaths
print os.path.abspath(os.path.split(sys.argv[0])[0])  # C:\filepaths
print os.path.dirname(os.path.abspath(__file__))      # C:\filepaths
print os.path.dirname(os.path.realpath(sys.argv[0]))  # C:\filepaths
print os.path.dirname(__file__)                       # (empty string)
print

print inspect.getfile(inspect.currentframe())         # lib/bar.py

print os.path.abspath(inspect.getfile(inspect.currentframe())) # C:\filepaths\lib\bar.py
print os.path.dirname(os.path.abspath(inspect.getfile(inspect.currentframe()))) # C:\filepaths\lib
print

print os.path.abspath(inspect.stack()[0][1])          # C:\filepaths\lib\bar.py
print os.path.dirname(os.path.abspath(inspect.stack()[0][1]))  # C:\filepaths\lib
print
Plasmagel answered 6/8, 2015 at 22:50 Comment(0)
S
80

I think this is cleaner:

import inspect
print inspect.stack()[0][1]

and gets the same information as:

print inspect.getfile(inspect.currentframe())

Where [0] is the current frame in the stack (top of stack) and [1] is for the file name, increase to go backwards in the stack i.e.

print inspect.stack()[1][1]

would be the file name of the script that called the current frame. Also, using [-1] will get you to the bottom of the stack, the original calling script.

Sebastian answered 8/7, 2011 at 17:50 Comment(3)
Do not recommend relying on the position inside the tuple. It's not clear at all what data you're trying to get when reading the code.Tine
inspect.getfile() returns the __file__ attribute if passed a module object. inspect.currentframe() returns the module. Ergo, this is an expensive way of saying __file__.Bullpup
inspect.stack() is a pretty expensive function, more so than just inspect.currentframe(), and it too calls inspect.getfile() on a module object.Bullpup
K
51
import os
os.path.dirname(__file__) # relative directory path
os.path.abspath(__file__) # absolute file path
os.path.basename(__file__) # the file name only
Kuopio answered 6/2, 2015 at 1:5 Comment(2)
I just tried @Pat Notz's comment. I think you could just get the filename through __file__.Lyle
In Python3, os.path.dirname will give you the relative path from where you are running the script. e.g. in python ../../test.py the os.path.dirname will be ../../ and not the absolute path to the script. I was looking for abspath but removing the name of the script. The first element of sys.path apparently is the answer sys.path[0].Hiltonhilum
C
38

The suggestions marked as best are all true if your script consists of only one file.

If you want to find out the name of the executable (i.e. the root file passed to the python interpreter for the current program) from a file that may be imported as a module, you need to do this (let's assume this is in a file named foo.py):

import inspect

print inspect.stack()[-1][1]

Because the last thing ([-1]) on the stack is the first thing that went into it (stacks are LIFO/FILO data structures).

Then in file bar.py if you import foo it'll print bar.py, rather than foo.py, which would be the value of all of these:

  • __file__
  • inspect.getfile(inspect.currentframe())
  • inspect.stack()[0][1]
Charla answered 26/2, 2010 at 22:25 Comment(2)
It works well but not for unit test on eclipse, I got /home/user/Softwares/eclipse/plugins/org.python.pydev_4.5.5.201603221110/pysrcOstracism
This is an expensive way of spelling sys.modules['__main__'].__file__, really.Bullpup
N
31

Since Python 3 is fairly mainstream, I wanted to include a pathlib answer, as I believe that it is probably now a better tool for accessing file and path information.

from pathlib import Path

current_file: Path = Path(__file__).resolve()

If you are seeking the directory of the current file, it is as easy as adding .parent to the Path() statement:

current_path: Path = Path(__file__).parent.resolve()
Nautilus answered 23/8, 2019 at 19:19 Comment(0)
P
16

It's not entirely clear what you mean by "the filepath of the file that is currently running within the process". sys.argv[0] usually contains the location of the script that was invoked by the Python interpreter. Check the sys documentation for more details.

As @Tim and @Pat Notz have pointed out, the __file__ attribute provides access to

the file from which the module was loaded, if it was loaded from a file

Panchromatic answered 8/9, 2008 at 19:42 Comment(1)
"print os.path.abspath( file )" and "print inspect.getfile( inspect.currentframe() )" doesn't work when we pass the python program to a win32 exe. Only sys.argv[0] works! :) but you only get the name!Dorladorlisa
M
15
import os
print os.path.basename(__file__)

this will give us the filename only. i.e. if abspath of file is c:\abcd\abc.py then 2nd line will print abc.py

Maceio answered 11/8, 2013 at 3:5 Comment(0)
P
13

I have a script that must work under windows environment. This code snipped is what I've finished with:

import os,sys
PROJECT_PATH = os.path.abspath(os.path.split(sys.argv[0])[0])

it's quite a hacky decision. But it requires no external libraries and it's the most important thing in my case.

Pincas answered 8/8, 2012 at 9:42 Comment(1)
I had to "import os, sys" for this, but so far it's the best answer that actually returns just the path without a file name at the end of the string.Edlyn
S
13

Try this,

import os
os.path.dirname(os.path.realpath(__file__))
Silsbye answered 22/2, 2019 at 17:31 Comment(0)
L
9

The __file__ attribute works for both the file containing the main execution code as well as imported modules.

See https://web.archive.org/web/20090918095828/http://pyref.infogami.com/__file__

Labannah answered 8/9, 2008 at 19:56 Comment(0)
D
9
import os
os.path.dirname(os.path.abspath(__file__))

No need for inspect or any other library.

This worked for me when I had to import a script (from a different directory then the executed script), that used a configuration file residing in the same folder as the imported script.

Delisadelisle answered 24/6, 2014 at 15:4 Comment(3)
This will not produce the desired answer if the current working directory (os.getcwd) is different from the directory in which the file is located.Paedogenesis
How so? Works fine for me in this case. I get the directory the file is located in.Paintbrush
@IronPillow maybe this answer will help you with what you need. https://mcmap.net/q/13581/-python-nameerror-global-name-39-__file__-39-is-not-definedDelisadelisle
M
8
import sys

print sys.path[0]

this would print the path of the currently executing script

Mitchellmitchem answered 2/1, 2010 at 18:34 Comment(2)
sys.path[0] is very useful, but gives the path of script1, not script3 as requestedBoche
At least on OS X, with 2.7, I don't find this does anything reliable. It works if executing directly the same file. Doesn't work from repl, especially from an imported eggMountford
C
6

I think it's just __file__ Sounds like you may also want to checkout the inspect module.

Crofton answered 8/9, 2008 at 19:44 Comment(1)
Ahhh... execfile is tricky. See my other post about using the inspect module.Crofton
K
5

You can use inspect.stack()

import inspect,os
inspect.stack()[0]  => (<frame object at 0x00AC2AC0>, 'g:\\Python\\Test\\_GetCurrentProgram.py', 15, '<module>', ['print inspect.stack()[0]\n'], 0)
os.path.abspath (inspect.stack()[0][1]) => 'g:\\Python\\Test\\_GetCurrentProgram.py'
Kipkipling answered 9/9, 2008 at 0:0 Comment(0)
A
4
import sys
print sys.argv[0]
Ayah answered 19/4, 2010 at 7:47 Comment(1)
Unfortunately this only works if the script was called with its full path, because it only returns the "first argument" on the command line, which is the calling to the script.Kinematograph
E
4

This should work:

import os,sys
filename=os.path.basename(os.path.realpath(sys.argv[0]))
dirname=os.path.dirname(os.path.realpath(sys.argv[0]))
Exhibitor answered 14/6, 2015 at 16:37 Comment(0)
B
4
print(__file__)
print(__import__("pathlib").Path(__file__).parent)
Bettinabettine answered 5/5, 2019 at 1:19 Comment(1)
Code only answers are discouraged. Please add some explanation as to how this solves the problem, or how this differs from the existing answers. From ReviewRetroaction
F
3

Here is what I use so I can throw my code anywhere without issue. __name__ is always defined, but __file__ is only defined when the code is run as a file (e.g. not in IDLE/iPython).

if '__file__' in globals():
    self_name = globals()['__file__']
elif '__file__' in locals():
    self_name = locals()['__file__']
else:
    self_name = __name__

Alternatively, this can be written as:

self_name = globals().get('__file__', locals().get('__file__', __name__))
Felicio answered 28/6, 2019 at 1:28 Comment(0)
S
2

To get directory of executing script

print os.path.dirname( inspect.getfile(inspect.currentframe()))
Spate answered 10/5, 2017 at 10:51 Comment(1)
This only works for python 2Pulsatile
W
0

I used the approach with __file__
os.path.abspath(__file__)
but there is a little trick, it returns the .py file when the code is run the first time, next runs give the name of *.pyc file
so I stayed with:
inspect.getfile(inspect.currentframe())
or
sys._getframe().f_code.co_filename

Wilbert answered 1/3, 2011 at 9:23 Comment(0)
O
0

I wrote a function which take into account eclipse debugger and unittest. It return the folder of the first script you launch. You can optionally specify the __file__ var, but the main thing is that you don't have to share this variable across all your calling hierarchy.

Maybe you can handle others stack particular cases I didn't see, but for me it's ok.

import inspect, os
def getRootDirectory(_file_=None):
    """
    Get the directory of the root execution file
    Can help: https://mcmap.net/q/13307/-how-do-i-get-the-path-and-name-of-the-python-file-that-is-currently-executing
    For eclipse user with unittest or debugger, the function search for the correct folder in the stack
    You can pass __file__ (with 4 underscores) if you want the caller directory
    """
    # If we don't have the __file__ :
    if _file_ is None:
        # We get the last :
        rootFile = inspect.stack()[-1][1]
        folder = os.path.abspath(rootFile)
        # If we use unittest :
        if ("/pysrc" in folder) & ("org.python.pydev" in folder):
            previous = None
            # We search from left to right the case.py :
            for el in inspect.stack():
                currentFile = os.path.abspath(el[1])
                if ("unittest/case.py" in currentFile) | ("org.python.pydev" in currentFile):
                    break
                previous = currentFile
            folder = previous
        # We return the folder :
        return os.path.dirname(folder)
    else:
        # We return the folder according to specified __file__ :
        return os.path.dirname(os.path.realpath(_file_))
Ostracism answered 14/6, 2016 at 15:6 Comment(0)
R
0

Simplest way is:

in script_1.py:

import subprocess
subprocess.call(['python3',<path_to_script_2.py>])

in script_2.py:

sys.argv[0]

P.S.: I've tried execfile, but since it reads script_2.py as a string, sys.argv[0] returned <string>.

Ruling answered 8/6, 2018 at 12:29 Comment(0)
V
0

The following returns the path where your current main script is located at. I tested this with Linux, Win10, IPython and Jupyter Lab. I needed a solution that works for local Jupyter notebooks as well.

import builtins
import os
import sys

def current_dir():
    if "get_ipython" in globals() or "get_ipython" in dir(builtins):
        # os.getcwd() is PROBABLY the dir that hosts the active notebook script.
        # See also https://github.com/ipython/ipython/issues/10123
        return os.getcwd()
    else:
        return os.path.abspath(os.path.dirname(sys.argv[0]))
Vacationist answered 19/1, 2022 at 15:14 Comment(0)
O
0

I'd like to go above and beyond since I need even more information. Here is how to obtain the:

  1. full path to the script being run
  2. directory of the script
  3. base filename of the script
  4. filename without the extension
  5. extension of the script
  6. home directory of the user running the script
  7. home directory of the user in whose home directory the script resides

From get_script_path.py in my eRCaGuy_hello_world repo:

import os
import sys

FULL_PATH_TO_SCRIPT = os.path.abspath(__file__)
SCRIPT_DIRECTORY = str(os.path.dirname(FULL_PATH_TO_SCRIPT))
SCRIPT_PARENT_DIRECTORY = str(os.path.dirname(SCRIPT_DIRECTORY))
# this also works, but its output will have the two dots (`/..`) in it.
SCRIPT_PARENT_DIRECTORY2 = f"{SCRIPT_DIRECTORY}/.."
FILENAME = str(os.path.basename(FULL_PATH_TO_SCRIPT))
FILENAME_NO_EXTENSION = os.path.splitext(FILENAME)[0]
FILENAME_EXTENSION = os.path.splitext(FILENAME)[1]

# Other useful paths:

# home directory of the current, running user
HOME_DIR_USER = os.path.expanduser("~")
# Obtain the home dir of the user in whose home directory this script resides,
# which may *not* be the home dir of the current user! Ex: run this script
# as root, via `sudo`, and you'll see that `HOME_DIR_USER` != `HOME_DIR_SCRIPT`.
script_path_list = os.path.normpath(FULL_PATH_TO_SCRIPT).split(os.sep)
HOME_DIR_SCRIPT = os.path.join("/", script_path_list[1], script_path_list[2])

# Bonus: add the parent directory to the start of the system PATH variable so
# that you can import modules directly in that directory above this script!
sys.path.insert(0, SCRIPT_PARENT_DIRECTORY)
# Now, assuming there is a `config.py`` file in the `SCRIPT_PARENT_DIRECTORY`,
# you can import it directly, like this:
#
# import config.py
#

# Print results
print(f"__file__:                  {__file__}")
print(f"FULL_PATH_TO_SCRIPT:       {FULL_PATH_TO_SCRIPT}")
print(f"SCRIPT_DIRECTORY:          {SCRIPT_DIRECTORY}")
print(f"SCRIPT_PARENT_DIRECTORY:   {SCRIPT_PARENT_DIRECTORY}")
print(f"SCRIPT_PARENT_DIRECTORY2:  {SCRIPT_PARENT_DIRECTORY2}")
print(f"FILENAME:                  {FILENAME}")
print(f"FILENAME_NO_EXTENSION:     {FILENAME_NO_EXTENSION}")
print(f"FILENAME_EXTENSION:        {FILENAME_EXTENSION}")
print("---")
print(f"HOME_DIR_USER:             {HOME_DIR_USER}")
print(f"script_path_list:          {script_path_list}")
print(f"HOME_DIR_SCRIPT:           {HOME_DIR_SCRIPT}")

Example run and output, tested on Linux Ubuntu 20.04 and 22.04:

eRCaGuy_hello_world$ python/get_script_path.py
__file__:                  python/get_script_path.py
FULL_PATH_TO_SCRIPT:       /home/gabriel/GS/dev/eRCaGuy_hello_world/python/get_script_path.py
SCRIPT_DIRECTORY:          /home/gabriel/GS/dev/eRCaGuy_hello_world/python
SCRIPT_PARENT_DIRECTORY:   /home/gabriel/GS/dev/eRCaGuy_hello_world
SCRIPT_PARENT_DIRECTORY2:  /home/gabriel/GS/dev/eRCaGuy_hello_world/python/..
FILENAME:                  get_script_path.py
FILENAME_NO_EXTENSION:     get_script_path
FILENAME_EXTENSION:        .py
---
HOME_DIR_USER:             /home/gabriel
script_path_list:          ['', 'home', 'gabriel', 'GS', 'dev', 'eRCaGuy_hello_world', 'python', 'get_script_path.py']
HOME_DIR_SCRIPT:           /home/gabriel

When run as root: notice that HOME_DIR_USER, the active user's home dir, now changes:

eRCaGuy_hello_world$ sudo python/get_script_path.py
[sudo] password for gabriel:
__file__:                  python/get_script_path.py
FULL_PATH_TO_SCRIPT:       /home/gabriel/GS/dev/eRCaGuy_hello_world/python/get_script_path.py
SCRIPT_DIRECTORY:          /home/gabriel/GS/dev/eRCaGuy_hello_world/python
SCRIPT_PARENT_DIRECTORY:   /home/gabriel/GS/dev/eRCaGuy_hello_world
SCRIPT_PARENT_DIRECTORY2:  /home/gabriel/GS/dev/eRCaGuy_hello_world/python/..
FILENAME:                  get_script_path.py
FILENAME_NO_EXTENSION:     get_script_path
FILENAME_EXTENSION:        .py
---
HOME_DIR_USER:             /root
script_path_list:          ['', 'home', 'gabriel', 'GS', 'dev', 'eRCaGuy_hello_world', 'python', 'get_script_path.py']
HOME_DIR_SCRIPT:           /home/gabriel

Additional explanation for finding HOME_DIR_SCRIPT

...which is the home directory of the path in which your Python script resides.

If the path to your script is /home/gabriel/GS/dev/eRCaGuy_dotfiles/useful_scripts/cpu_logger.py, and you wish to obtain the home directory part of that path, which is /home/gabriel, you can do this:

import os

# Obtain the home dir of the user in whose home directory this script resides
script_path_list = os.path.normpath(os.path.abspath(__file__)).split(os.sep)
home_dir = os.path.join("/", script_path_list[1], script_path_list[2])

To help make sense of this, here are the paths for os.path.abspath(__file__), script_path_list, and home_dir. Notice that script_path_list is a list of the path components, with the first element being an empty string since it originally contained the / root dir path separator for this Linux path:

os.path.abspath(__file__): /home/gabriel/GS/dev/eRCaGuy_dotfiles/useful_scripts/cpu_logger.py
script_path_list:          ['', 'home', 'gabriel', 'GS', 'dev', 'eRCaGuy_dotfiles', 'useful_scripts', 'cpu_logger.py']
home_dir:                  /home/gabriel

My answer where I first documented this: Python: obtain the path to the home directory of the user in whose directory the script being run is located [duplicate]

See also

  1. My answer on how to do the same thing in Bash: How to obtain the full file path, full directory, and base filename of any script being run OR sourced... ...even when the called script is called from within another bash function or script, or when nested sourcing is being used!
  2. This related, useful answer to: How do I get the parent directory in Python?
Outwardly answered 14/12, 2022 at 15:47 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.