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


Python Path.load方法代碼示例

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


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

示例1: diff_files

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import load [as 別名]
def diff_files(fname, path1, path2, indent, diff_system=False):

    #until we prove otherwise, we'll assume they're different
    is_difference = True
    p1 = Path(path1)
    n1 = p1.load()
    #n1 = make_node(path1)

    p2 = Path(path2)
    n2 = p2.load()
    #n2 = make_node(path2)

    if n1.size == n2.size:
        #probably pretty safe to assume that they are equal
        #print " %s - BOTH, SAME SIZE" % phraseUnicode2ASCII(fname)
        #print "EQUAL sizes: %s %s" % (n1.size, n2.size)
        is_difference = False

        #could do additional checks if desired
        #enabling another diff level will take longer, but will be more accurate:
        f_a = file(path1)
        f_b = file(path2)
        a = f_a.readlines()
        b = f_b.readlines()
        diff = unified_diff(a, b)
        for d in diff:
            is_difference = True
            #print d

        #this will signal which files have differences:
        if is_difference:
            print(" %s - BOTH, DIFFERENT CONTENT" % fname.translate(unaccented_map()))
            
        #could move it somewhere else:
        #os.rename(path1, os.path.join(d1, "dupes", fname))
        #os.rename(path2, os.path.join(d2, "merged", fname))

    else:
        #print " %s - BOTH, DIFFERENT SIZE" % phraseUnicode2ASCII(fname)
        print(" %s - BOTH, DIFFERENT SIZE" % fname.translate(unaccented_map()))
        if diff_system:
            print("diffing: %s %s\n" % (path1, path2))
            try:
                #diff_system( phraseUnicode2ASCII(path1),
                #             phraseUnicode2ASCII(path2) )
                #diff_playlists(n1, n2)
                diff_system( path1.translate(unaccented_map()),
                             path2.translate(unaccented_map()) )
            except:
                print("Unable to diff.")

    return is_difference
開發者ID:charlesbrandt,項目名稱:templates,代碼行數:54,代碼來源:diff_json_and_merge.py

示例2: collection_zip

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import load [as 別名]
def collection_zip(collection_name=None, content_name=None):
    """

    """
    result = ''
    content = None
    if collection_name:
        summary = get_summary(collection_name)
        content = summary.load_content(content_name)
        if content:

            sources = []
            content.zips = find_zips(content.path)
            import zipfile
            for zipf in content.zips:
                zipp = Path(zipf)
                #print zipp.name
                zip_root = os.path.join(content.path, zipp.name)
                if not os.path.exists(zip_root):
                    os.makedirs(zip_root)
                zfile = zipfile.ZipFile(zipf)
                for name in zfile.namelist():
                    (dirname, filename) = os.path.split(name)
                    #print "Decompressing " + filename + " on " + dirname
                    dest_dir = os.path.join(zip_root, dirname)
                    if not dest_dir in sources:
                        sources.append(dest_dir)
                    print("Decompressing " + filename + " to " + dest_dir + "<br>")
                    if not os.path.exists(dest_dir):
                         os.makedirs(dest_dir)
                    dest = os.path.join(dest_dir, name)
                    if not os.path.exists(dest):
                        fd = open(dest, "w")
                        fd.write(zfile.read(name))
                        fd.close()
                        dpath = Path(dest)
                        print("making thumb")
                        img = dpath.load()
                        img.make_thumbs(['small'], save_original=False)


            zips = []
            for source in sources:
                spath = Path(source, relative_prefix=path_root)
                sdir = spath.load()
                zips.append(sdir.contents)
                print(source)

    #return template('simple', body=result, title="unzip!")
    return template('zip', zips=zips)
開發者ID:charlesbrandt,項目名稱:medley,代碼行數:52,代碼來源:application.py

示例3: path

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import load [as 別名]
def path(relative=''):
    """
    serve a static file

    this also allows pose to function as a customizable file system browser

    be careful with what you set path_root to
    if the machine you run this on has sensitive information
    and is connected to a public network
    """
    global path_root

    if re.match('~', relative):
        relative = os.path.expanduser(relative)
    ## else:
    ##     relative = os.path.join('/', relative)
    ##     full = os.path.abspath(relative)
    ## print full

    full_path = os.path.join(path_root, relative)
 
    path = Path(full_path, relative_prefix=path_root)
    if path.type() == "Directory":
        node = path.load()
        #will depend what we want to sort by here:
        node.sort_by_path()
        #node.sort_by_date()
        return template('directory', path=path, contents=node.contents)
    else:
        #this is equivalent to a view...
        #indicate it in the log:
        #path.log_action()
        return static_file(relative, root=path_root)
開發者ID:charlesbrandt,項目名稱:mindstream,代碼行數:35,代碼來源:application.py

示例4: add_new

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import load [as 別名]
def add_new(source_list, source_dir, destination=None):
    #ignores = ["classics", "misc", "other", "youtube-dl", "playlists"]
    ignores = ["playlists"]

    m3u = M3U(source_list)
    if os.path.isdir(source_dir):
        source_dir_path = Path(source_dir)
        subdirs = source_dir_path.load().directories
        #subdirs = os.listdir(source_dir)
        for subdir in subdirs:
            print("")
            if check_ignore(str(subdir), ignores):
                print("SKIP (IGNORES): %s" % subdir)
            else:
                print("SUBDIR: %s" % subdir)
                scan_dir(m3u, subdir)

        scan_dir(m3u, source_dir)


    else:
        print("NOT A DIRECTORY: %s" % source_dir)

    print("")
    print("")
    #for item in m3u:
    #    print item
    if destination is None:
        source_list_path = Path(source_list)
        dest_name = Timestamp().compact(accuracy="day") + "-videos.m3u"
        destination = os.path.join(str(source_list_path.parent()), dest_name)
        
    print("Saving to: %s" % destination)
    m3u.save(destination)
開發者ID:charlesbrandt,項目名稱:medley,代碼行數:36,代碼來源:update_playlist.py

示例5: rotate_image

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import load [as 別名]
def rotate_image(source, degrees):
    if os.path.exists(source):
        p = Path(source)
        assert p.type() == "Image"
        i = p.load()
        print("Rotating %s by %s degrees" % (source, degrees))
        i.rotate(degrees)
        #i.auto_rotate()
        
    else:
        print("Couldn't find path: %s" % source)
        exit()
開發者ID:charlesbrandt,項目名稱:templates,代碼行數:14,代碼來源:rotate_image.py

示例6: find_jsons

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import load [as 別名]
def find_jsons(item, limit_by_name=False, debug=False):
    """
    foundation for find_json
    but this returns all matches (based on parameters)
    """

    if re.search('.*\.json$', item):
        if debug:
            #print "find_and_load_json: item is a json string: %s" % item
            logging.debug("find_json: item is a json string: %s" % item)
        return [item]

    else:
        parent = ''
        name = ''
        p = Path(item)
        if p.type() == "Directory":
            #item must be a directory... just look here
            parent = p
            d = p.load()
        else:
            name = to_tag(p.name)
            #must be some other file type... load the parent directory:
            parent = p.parent()
            d = parent.load()
            if debug:
                print("%s not a directory, using: %s" % (item, parent))
            
        matches = []
        for j in d.files:
            #if debug:
            #    print "Checking: %s" % j
            if re.search('\.json$', str(j)):
                if debug:
                    print("matched json: %s" % j)

                match = os.path.join(str(parent), str(j))
                #this should allow us to hone in on one
                #if there is more than one media file in a directory
                if name and limit_by_name:
                    if re.search(name, str(j)):
                        matches.append(match)
                    else:
                        if debug:
                            print("could not find %s in %s" % (name, str(j)))
                else:
                    matches.append(match)

        if debug:
            print("Found the following: %s" % matches)

        return matches
開發者ID:charlesbrandt,項目名稱:medley,代碼行數:54,代碼來源:helpers.py

示例7: extract_zips

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import load [as 別名]
def extract_zips(source, make_subdir=True):
    """
    take a source
    make sure it has not been extracted already
    unzip the file
    """

    path = Path(source)
    source = path.load()
    #print source.directories
    for d in source.directories:
        #print d.path
        dpath = d.load()
        for f in dpath.files:
            #must have a zip file
            if re.search('.zip', f.path) and f.extension == '.zip':
                if make_subdir:
                    # this uses the zip's filename for the directory
                    #destination = os.path.join(str(f.parent()), str(f.name))
                    # sometimes the zip is not descriptive...
                    # better to use the parent directory name
                    destination = os.path.join(str(f.parent()), str(f.parent().name))
                    dest_path = Path(destination)
                else:
                    #otherwise, just put them in the main directory
                    #dest_path = Path(destination)
                    destination = str(f.parent())
                    dest_path = f.parent()

                #TODO:
                #create a file to indicate the extract already happen
                #to skip on future runs
                #if not alredy_extracted.exists():
                #if not dest_path.exists():
                #else:
                #    print "already extracted: %s" % f.path

                #print "extracting: %s" % f.path
                #this extracts to the dpath directory, not a new
                #subdirectory with the same name (like we are checking for)
                #good enough for this round, but may want to improve on that
                #command = "unzip %s -d %s" % (f.path, d.path)
                #command = "unzip %s -d %s" % (f.path, destination)
                #adding -fo option -f: freshen -o: overwrite without prompting
                command = "unzip -o %s -d %s" % (f.path, destination)
                print("not found, unzipping: %s" % command)
                process = subprocess.Popen(command, shell=True, stdout=subprocess.PIPE,
                                           stderr=subprocess.PIPE)
                output = process.communicate()[0]
                if output:
                    print(output)
開發者ID:charlesbrandt,項目名稱:templates,代碼行數:53,代碼來源:extract_zips.py

示例8: size_of_list

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import load [as 別名]
def size_of_list(source, media_root=None, ignores=['/c/',]):
    """
    ignores are used to distinguish actual media from markers
    """
    items = []
    if re.search('.m3u', source):
        items = M3U(source)

    elif re.search('.json', source):
        loaded = load_json(source)

        #see if we have a dictionary or a list:
        if isinstance(loaded, list):
            #already have a list
            #clean it up
            for item in loaded:
                #these are usually content .json files:
                content = Content(item[0])
                #print content.media
                items.append(content.media[-1][0])
        elif isinstance(loaded, dict):
            #walk the tree to load each item individually
            #could call size_of_list() recursively
            pass

    total_size = 0
    total_items = 0
    #seconds?
    total_length = 0
    for item in items:
        check_item = False
        if media_root and re.match(media_root, item):
            check_item = True
        #elif not re.match(ignore, item):
        elif not check_ignore(item, ignores):
            check_item = True

        if check_item:
            p = Path(item)
            f = p.load()

            total_size += f.check_size()
            results = get_media_properties(item)
            print(results)
            total_length += results[1]
            total_items += 1
            #print item

    print("found %s matching items" % total_items)
    return total_size, total_length, total_items
開發者ID:charlesbrandt,項目名稱:medley,代碼行數:52,代碼來源:size_of_playlist_items.py

示例9: group_by_day

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import load [as 別名]
def group_by_day(path, dest_prefix=None, tags=[]):
    """
    look at a directory, and group all files by the day they were created

    run through a supplied directory's files
    create sub-directories that correspond to the day of the files' timestamps
    move the files to their corresponding day subdirectory
    in the new_dir destination

    """
    if dest_prefix is None:
        dest_prefix = path
    p = Path(path)
    d = p.load()
    #d = make_node(path)
    d.sort_by_date()

    dates = []
    destinations = []

    last_date = None
    cur_batch = []
    print("%s Files found in %s" % (len(d.files), path))
    for fpath in d.files:
        #print f.name
        f = fpath.load()
        if f.date() != last_date:
            #check if we need to move the previous day's files:
            print("New day: %s (previously: %s)" % (f.date(), last_date))
            if cur_batch:
                dest = process_batch(cur_batch, last_date, dest_prefix, tags)
                destinations.append(dest)

            cur_batch = [ f ]
            last_date = f.date()
        else:
            cur_batch.append(f)

    #get the last one:
    if cur_batch:
        dest = process_batch(cur_batch, last_date, dest_prefix, tags)
        if not dest in destinations:
            destinations.append( dest )

    #if we need to do something else to the new directories
    #we have them all collected in destinations list

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

示例10: find_media

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import load [as 別名]
def find_media(item):
    """
    using this in content.import_content to check for time based media
    (videos or sounds)
    """
    p = Path(item)
    if p.type() == "Directory":
        root = p.load()
    else:
        parent = p.parent()
        root = parent.load()

    matches = []
    #now root is a directory...
    #use that to help find media
    root.scan_filetypes()
    matches.extend(root.sounds)
    matches.extend(root.movies)
    return matches
開發者ID:charlesbrandt,項目名稱:medley,代碼行數:21,代碼來源:helpers.py

示例11: reset_images

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import load [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

示例12: main

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import load [as 別名]
def main():
    #requires that at least one argument is passed in to the script itself
    #(through sys.argv)
    if len(sys.argv) > 1:
        helps = ['--help', 'help', '-h']
        for i in helps:
            if i in sys.argv:
                usage()
                exit()

        #skip the first argument (filename):
        for arg in sys.argv[1:]:
            print(arg)

            path = Path(arg)
            source = path.load()
            #print(source.directories)
            for d in source.directories:
                print("looking in: ", d)
                extract_zips(d)
    else:
        usage()
        exit()
開發者ID:charlesbrandt,項目名稱:templates,代碼行數:25,代碼來源:extract_zips.py

示例13: find_and_load_json

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import load [as 別名]
def find_and_load_json(item, debug=False):
    """
    look in the same directory as item for a json file
    if found, load it and return the loaded object
    otherwise return None

    also [2013.07.03 10:30:19]
    deprecated:
    probably better to find_json()
    then load_json()
    """
    if re.search('.*\.json', item):
        if debug:
            #print "find_and_load_json: item is a json string: %s" % item
            logging.debug("find_and_load_json: item is a json string: %s" % item)
        loaded = load_json(item)
    else:
        p = Path(item)
        if p.type() == "Directory":
            parent = p
            d = p.load()
        else:
            parent = p.parent()
            d = parent.load()
            
        loaded = None
        for j in d.files:
            if re.search('.*\.json', str(j)):
                logging.debug("find_and_load_json: loading from: %s" % j)
                #print "find_and_load_json: loading from: %s" % j

                match = os.path.join(str(parent), str(j))
                loaded = load_json(match)
                #jso = file(os.path.join(str(parent), str(j)))
                #loaded = json.loads(jso.read())
                
    return loaded
開發者ID:charlesbrandt,項目名稱:medley,代碼行數:39,代碼來源:helpers.py

示例14: check_dates

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import load [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

示例15: benchmark

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import load [as 別名]
def benchmark(source):
    """
    run through all tests, timing along the way

    timeit gets mentioned many times:
    http://docs.python.org/3.4/library/timeit.html
    """

    print("Testing moments: ") 
    start_time = time.time()

    print("making path:")
    step_time = time.time()    
    pic = Path(source)
    print(time.time() - step_time, "seconds")
    print("")

    
    print("loading path:")
    step_time = time.time()    
    img = pic.load()
    print(time.time() - step_time, "seconds")
    print("")

    #13.3232491016 seconds:
    ## print "make thumbs: (all)"
    ## step_time = time.time()    
    ## img.make_thumbs()
    ## print time.time() - step_time, "seconds"
    ## print ""

    ## print "removing thumbs: (all)"
    ## step_time = time.time()    
    ## shutil.rmtree("sized")
    ## print time.time() - step_time, "seconds"
    ## print ""

    #3.2377550602 seconds:
    ## print "make thumbs: (tiny)"
    ## step_time = time.time()    
    ## img.make_thumbs(["tiny"])
    ## print time.time() - step_time, "seconds"
    ## print ""

    ## print "removing thumbs: (tiny)"
    ## step_time = time.time()    
    ## shutil.rmtree("sized")
    ## print time.time() - step_time, "seconds"
    ## print ""

    #now break it down to steps:

    #0.000612020492554 seconds
    ## print "make thumbs dirs()"
    ## step_time = time.time()    
    ## img.make_thumb_dirs()
    ## print time.time() - step_time, "seconds"
    ## print ""

    ## print "removing thumbs dirs"
    ## step_time = time.time()    
    ## shutil.rmtree("sized")
    ## print time.time() - step_time, "seconds"
    ## print ""

    #0.00586199760437 seconds
    print("Open image with PIL: ") 
    step_time = time.time()
    image = PILImage.open(source)
    print(time.time() - step_time, "seconds")
    print("")

    print("show sizes: ") 
    step_time = time.time()
    print(image.size)
    print(time.time() - step_time, "seconds")
    print("")

    #0.56491112709 seconds
    print("Copy image buffer in PIL: ") 
    step_time = time.time()
    square = image.copy()
    print(time.time() - step_time, "seconds")
    print("")

    print("resize max: ") 
    step_time = time.time()
    pre_crop = resize_max(400, image.size[0], image.size[1])
    print(pre_crop)
    print(time.time() - step_time, "seconds")
    print("")
    
    #0.108213186264 seconds
    print("Square image (includes copy)") 
    step_time = time.time()
    square = img._square_image(square)    
    print(time.time() - step_time, "seconds")
    print("")

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


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