當前位置: 首頁>>代碼示例>>Python>>正文


Python Path.exists方法代碼示例

本文整理匯總了Python中moments.path.Path.exists方法的典型用法代碼示例。如果您正苦於以下問題:Python Path.exists方法的具體用法?Python Path.exists怎麽用?Python Path.exists使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在moments.path.Path的用法示例。


在下文中一共展示了Path.exists方法的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: main

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import exists [as 別名]
def main():
    if len(sys.argv) > 1:
        helps = ['--help', 'help', '-h']
        for i in helps:
            if i in sys.argv:
                usage()
                exit()

        f1 = sys.argv[1]
        if len(sys.argv) > 2:
            f2 = sys.argv[2]
        else:
            f1_path = Path(f1)
            f1_dir = f1_path.parent()
            
            f2 = os.path.join(str(f1_dir), "summary.txt")
            f2_path = Path(f2)
            if not f2_path.exists():
                print("Saving output to: %s" % f2)
            else:
                print("Warning: %s exists!" % f2)
                exit()

        create_summary(f1, f2)
    else:
        usage()
        exit()
開發者ID:charlesbrandt,項目名稱:mindstream,代碼行數:29,代碼來源:time_report.py

示例2: process_files

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import exists [as 別名]
def process_files(source_list, translate=None, action="copy", m3u_dest="temp.txt"):
    """
    copy *only* the files referenced in a source_list to a new loacation
    """
    result = ''
    
    #j = Journal()
    #j.from_file(journal)
    #j = load_journal(journal)
    #m = MediaList()
    #m.from_journal(j, local_path='/c')
    #sources = Sources()

    sl = Path(source_list)
    assert sl.exists()
    converter = Converter()

    if sl.extension == ".m3u":
        print("M3U!")
        sources = converter.from_m3u(source_list)
    elif sl.extension == ".txt":
        sources = converter.from_journal(source_list)
    else:
        print("UNKNOWN EXTENSION: %s" % sl.extension)

    
    new_sources = Sources()
    counter = 0
    for i in sources:
        #print i
        #if re.search('\.mp3', i.path):
        if os.path.exists(str(i.path)):
            destination = make_destination(i.path, translate)
            #print "SOURCE: %s" % i
            print("DEST: %s" % destination)

            if action == "copy":
                print("Copy %03d: %s" % (counter, i.path))
                copy_file(i.path, destination)
            if action == "m3u":
                new_sources.append(Source(destination))
        else:
            print("COULD NOT FIND FILE: %s" % i.path)
        counter += 1

    if action == "m3u":
        #print len(new_sources)
        m3u = converter.to_m3u(new_sources, verify=False)
        #print m3u
        print("SAVING M3U TO: %s" % m3u_dest)
        f = open(m3u_dest, 'w')
        f.write(m3u)
        f.close()
開發者ID:charlesbrandt,項目名稱:medley,代碼行數:55,代碼來源:copy_media.py

示例3: play

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import exists [as 別名]
def play(source='', start=0):
    """
    source should be either a path or a string
    if it's just a string, then should try to identify the correct path to the media
    (search a library of local data?)
    """
    process = None
    p = Path(source)
    if not p.exists():
        #TODO
        #could search here
        #but for now...
        print("Could not find: %s" % source)
    else:
        process = vlc(source, start)
    return process
開發者ID:charlesbrandt,項目名稱:moments,代碼行數:18,代碼來源:launch.py

示例4: reset_images

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import exists [as 別名]
def reset_images(source):
    print("Looking in: %s" % source)
    path = Path(source)
    if path.exists() and path.type() == "Directory":
        d = path.load()
        d.scan_filetypes()
        #print d.images
        for image in d.images:
            #print image
            i = image.load()
            print("old: %s" % i.datetime())
            i.datetime_exif()
            i = image.load()
            print("new: %s" % i.datetime())
            print()
            
        #print d.directories
        for sub_d in d.directories:
            reset_images(sub_d)
    else:
        print("Couldn't find path: %s" % source)
        exit()
開發者ID:charlesbrandt,項目名稱:templates,代碼行數:24,代碼來源:reset_image_times.py

示例5: check_dates

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import exists [as 別名]
def check_dates(sources):
    """
    go through all sources and look for the days covered
    this is useful to check for media from
    devices that don't keep an accurate clock

    related to group_by_day, but not processing any batches here
    """
    dates = []
    for source in sources:
        p = Path(source)
        if p.exists():
            d = p.load()
            #print(d)
            #print(type(d))
            d.sort_by_date()

            for fpath in d.files:
                #print f.name
                f = fpath.load()
                if not f.date() in dates:
                    dates.append(f.date())

    return dates
開發者ID:charlesbrandt,項目名稱:mindstream,代碼行數:26,代碼來源:import_media.py

示例6: save

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import exists [as 別名]
def save(relative=''):
    # debug:
    # print(dir(bottle.request.forms))
    # print("Keys: %s" % (bottle.request.forms.keys()))
    # print("Values: %s" % (bottle.request.forms.values()))

    global path_root

    if re.match('~', relative):
        relative = os.path.expanduser(relative)

    if not relative:
        # could set a default here if it is desireable
        print("NO DESTINATION SENT!")
    elif not re.match('/', relative):
        relative = path_root + relative

    # destination = Path(relative, relative_prefix=path_root)
    # now check if the destination is a directory...
    # in that case, create a sortable.list name in the directory
    if os.path.isdir(relative):
        print("Relative directory passed in:", relative)
        path = Path(relative)
        print("Path loaded:", path)

        name = path.name + ".list"
        destination = os.path.join(relative, name)
        # TODO:
        # something recursive can happen here:
        # having difficulty replicating...
        # should work though!
        # destination = path.sortable_list_path()

        print("Destination:", destination)

        log_name = path.name + ".list.log"
        log_destination = os.path.join(relative, log_name)

    else:
        destination = relative
        log_destination = relative + ".log"

    # print(destination)

    # gets a string
    # could be json or text / list
    content = bottle.request.forms.get('content')
    # print("CONTENT:")
    # print(content)
    # print()

    save_as = bottle.request.forms.get('format')

    if destination:
        if save_as in ["list"]:
            dest_file = open(destination, 'w')
            # print("opened: ", destination)
            # print("writing (raw): ", content)
            dest_file.write(content)
            dest_file.close()
            print("saved content to: ", destination)

            # TODO:
            # check the .list.log file to see if today's entry already exists
            log_path = Path(log_destination)
            print("Log path: ", log_path)
            if log_path.exists():
                j = log_path.load_journal()
            else:
                j = log_path.load_journal(create=True)
            now = Timestamp()
            now.compact(accuracy='day')
            entries = j.range(now)
            print(entries)
            if len(entries):
                print("already had today logged")
            else:
                j.make(content, created=now)
                j.save(log_path)
                print("adding new entry")



            # this should be sufficient
            return("Success!")
        else:
            return("Unknown format: " + str(save_as))


        ## elif save_as == "json":
        ##     #could also do something like:
        ##     ordered_list = json.loads(content)
        ##     save_json(destination, ordered_list)
        ##     #but that seems like the same thing as above

        # if save() is being called via ajax,
        # redirecting here only causes extra load on the server
        # redirect("/text" + relative)
        # redirect("/path" + relative)

#.........這裏部分代碼省略.........
開發者ID:charlesbrandt,項目名稱:sortable_list,代碼行數:103,代碼來源:application.py

示例7: sort

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import exists [as 別名]
def sort(relative=''):
    """
    accept a path to a moment log and enable sorting on the items
    using jquery ui for a drag and drop interface
    """
    global path_root

    if re.match('~', relative):
        relative = os.path.expanduser(relative)
    if not re.match('/', relative):
        relative = path_root + relative

    #set some defaults here...
    #if they've been changed, this will get over written on load
    groups = { "all":[], "edit":[], "slide1":[], "slide2":[], "slide3":[], "slide4":[], "slide5":[], "slide6":[], "slide7":[], "slide8":[], "slide9":[], }

    tab_order = ['all', 'edit', "slide1", "slide2", "slide3", "slide4", "slide5", "slide6", "slide7", "slide8", "slide9"]

    path = Path(relative, relative_prefix=path_root)
    print(path)
    if path.exists() and path.type() == "Directory":
        response = "Error: need a file name to store the meta data in<br>"
        response = "You supplied a directory path: %s<br>" % path
        return response
    else:
        parent_directory = path.parent()
        if path.extension == ".txt":
            #create a text journal if we don't have one
            if not path.exists():
                #convert images to journal
                #print "PARENT: %s" % parent_directory
                directory = parent_directory.load()
                #print "directory: %s, of type: %s" % (directory, type(directory))
                directory.create_journal(journal=path.filename)
                #journal = path.load_journal(create=True)

            journal = path.load_journal()
            items = []
            for e in journal.entries():
                new_p = os.path.join(str(parent_directory), e.data.strip())
                #print new_p
                p = Path(new_p)
                #print p.exists()
                items.append(p)

            #initial version of groups:
            destination = Path(relative)
            destination.extension = '.json'

            groups['all'] = items
            
        elif path.extension == ".json":
            #we can make the initial version here...
            #skip the generation of a moments log step
            if not path.exists():
                directory = parent_directory.load()
                #print "directory: %s, of type: %s" % (directory, type(directory))
                directory.sort_by_date()
                directory.scan_filetypes()
                
                groups['all'] = directory.images
                
            else:
                loaded = load_groups(str(path))
                #template expects all items in groups to be Path objects.
                #do that now
                groups = {}
                for key, value in list(loaded.items()):
                    groups[key] = []
                    for v in value:
                        groups[key].append(Path(v))
            
            destination = Path(relative)

        else:
            #dunno!
            print("UNKNOWN FILE TYPE: %s" % relative)
            groups = {}
            destination = None

        #clean up tab_order as needed
        for key in list(groups.keys()):
            if not key in tab_order:
                tab_order.append(key)
        for item in tab_order[:]:
            if item not in list(groups.keys()):
                tab_order.remove(item)

        print(tab_order)
        
        #return template('sort', path=path, items=items)
        return template('sort', path=path, groups=groups, destination=destination, tab_order=tab_order)
開發者ID:charlesbrandt,項目名稱:mindstream,代碼行數:94,代碼來源:application.py

示例8: make_module

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import exists [as 別名]
def make_module(module_name, short_description):

    here = Path('.')
    print(here)

    #customize:
    version = "0.1.0"
    author = "Charles Brandt"
    email = "[email protected]"

    now = Timestamp()

    #should be passed in as an argument now
    #module_name = "Probe"
    module_low = module_name.lower()
    print(module_low)

    if (here.name != module_name) and (here.name != module_low):
        print("current directory name does not equal module name:")
        print("%s != %s" % (here.name, module_name))
        exit()

    #few different good options here:
    #url = 'http://pypi.python.org/pypi/%s/' % module_name
    #url = 'http://packages.python.org/%s/' % module_name
    url = 'https://bitbucket.org/cbrandt/%s/' % module_low

    #short_description = "Objects to help process and sort collections and their contents."


    module_path = Path(os.path.join(str(here), module_low))
    if not module_path.exists():
        module_path.create()
        print("Created: %s" % module_path)

    module_init = Path(os.path.join(str(module_path), "__init__.py"))
    if not module_init.exists():
        module_init.create()
        print("Created: %s" % module_init)


    #this is the other important thing to customize:
    setup = """from setuptools import setup
#haven't gotten this to work yet:
#from distutils.core import setup

setup(
    name='%s',
    version='%s',
    author='%s',
    author_email='%s',
    packages=['%s'],
    scripts=[],
    url='%s',
    license='LICENSE.txt',
    description='%s',
    long_description=open('README.txt').read(),
    install_requires=[
    ],
)
""" % (module_name, version, author, email, module_low, url, short_description)
    f = open("setup.py", 'w')
    f.write(setup)
    f.close()

    readme = "README.txt"
    if not os.path.exists(readme):
        f = open(readme, 'w')
        f.write("""==============
{module_name}
==============

{short_description}

DOCS
---------
Complete documentation can be found in:
docs/

To generate the documentation, you will need Sphinx:
sudo easy_install sphinx

cd docs/
sphinx-build -b html . ./_build/html/

or
make html

INSTALL
----------

see docs/installation.txt

and

docs/_build/html/installation.html


CONTRIBUTORS
-----------------
#.........這裏部分代碼省略.........
開發者ID:charlesbrandt,項目名稱:templates,代碼行數:103,代碼來源:new_module.py

示例9: download_with_browser_helper

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import exists [as 別名]
def download_with_browser_helper(driver, link, browser_root='/Users/user/Downloads/', filename=None, ping_page=None, ping_interval=None):
    """
    specialized download routine to use the browser to save files
    then poll for the file to be complete before moving on

    driver is an instance of a selenium/webdriver instance running a browser 

    if the download stalls, move on after a threshold is met

    this does not handle moving the file
    only returns true or false depending on if the file needed to be skipped
    because it stalled out.

    browser_root is the default location that browser is configured
    to download to
    browser should be set to automatically download files
    of the type you are downloading in order to automate the process
    """
    skipped = False

    #*2011.12.30 13:28:09
    #sometimes it's not possible to know the filename
    #until after you start the download
    #(that is, it only shows up in the directory.)
    #
    #to work around that, 
    #get the current files in the directory before starting the download
    #then look after and see what the difference is
    pre_files = os.listdir(browser_root)

    #this kicks off the actual download:
    driver.get(link)

    #make sure there has been time for .part to be created
    time.sleep(30)

    post_files = os.listdir(browser_root)
    new_files = []
    for f in post_files:
        if f not in pre_files:
            new_files.append(f)
    print("found these new files: %s" % new_files)
    assert len(new_files) < 3 and len(new_files) > 0

    for f in new_files:
        if not re.search('\.part', f):
            filename = f

    download_dest = os.path.join(browser_root, filename)
    dpart = download_dest + '.part'

    #start = Timestamp()
    stall_start = None
    stalled = False
    size = 0
    new_size = -1

    ping_start = Timestamp()

    dpartp = Path(dpart)
    #there is a chance it finished downloading if the file was small
    if dpartp.exists():
        dpartf = dpartp.load()
        while dpartp.exists():
            #do this before the sleep to make sure it's still there
            new_size = dpartf.check_size()
            time.sleep(10)
            now = Timestamp()

            if ping_page and ping_interval:
                if now.datetime > ping_start.future(minutes=ping_interval).datetime:
                    print("time to ping! %s, %s" % (now, ping_page))
                    driver.get(ping_page)
                    ping_start = Timestamp()
            
            
            #if the size has changed, something is happening
            #not stalled
            if new_size != size:
                if stalled:
                    now = Timestamp()
                    print("download resumed: %s" % now)

                stalled = False
                size = new_size

            #could just be slow to download, but want to at least check
            else:
                #we've already set it before
                if stalled:
                    #check if stall_start was 25 minutes ago

                    if now.datetime > stall_start.future(minutes=25).datetime:
                        print("stall threshold met. deleting: %s" % dest)
                        dpartp.remove()
                        dpath.remove()
                        #if we get here, we know it didn't work
                        skipped = True

                        #log skips to make sure we go back:
#.........這裏部分代碼省略.........
開發者ID:charlesbrandt,項目名稱:medley,代碼行數:103,代碼來源:scraper.py


注:本文中的moments.path.Path.exists方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。