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


Python Path.parent方法代碼示例

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


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

示例1: main

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

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

示例3: copy_up

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import parent [as 別名]
def copy_up(relative=''):
    """
    find the item at the supplied path
    and copy it up to the parent directory
    this is useful for images that should show up as the default image
    """
    global path_root

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

    full_path = os.path.join(path_root, relative)
    path = Path(full_path, relative_prefix=path_root)

    if path.type() == "Image":
        cur_dir = path.parent()
        parent = cur_dir.parent()

        path.copy(parent)

        #this should be sufficient
        return "Success!"

    else:
        return "Failed"
開發者ID:charlesbrandt,項目名稱:sortable_list,代碼行數:27,代碼來源:application.py

示例4: find_jsons

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

示例5: copy_media

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import parent [as 別名]
def copy_media(source, source_root, destination_root):
    m3u = M3U(source)

    total_size = 0
    total_items = 0
    for item in m3u:
        if re.match(source_root, item):
            p = Path(item)
            relative = p.to_relative(source_root)
            sparent = p.parent()
            destination = os.path.join(destination_root, relative)
            dpath = Path(destination)
            dparent = dpath.parent()
            print(relative)
            print(sparent)
            print(destination)

            if not os.path.exists(str(dparent)):
                os.makedirs(str(dparent))

            if not os.path.exists(destination):
                p.copy(destination)
            else:
                print("already have: %s" % destination)

            for option in os.listdir(str(sparent)):
                soption = os.path.join(str(sparent), option)
                spath = Path(soption)
                print(spath.type())
                if spath.type() != "Movie" and spath.type() != "Directory":
                    doption = os.path.join(str(dparent), option)
                    if not os.path.exists(doption):
                        print("copy here: %s, to %s" % (soption, doption))
                        shutil.copy(soption, doption)
                    
                

            print()
開發者ID:charlesbrandt,項目名稱:medley,代碼行數:40,代碼來源:copy_playlist_media.py

示例6: find_zips

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import parent [as 別名]
def find_zips(item):
    p = Path(item)
    if p.type() == "Directory":
        root = item
    else:
        parent = p.parent()
        root = str(parent)

    matches = []
    options = os.listdir(root)
    for o in options:
        if re.search('.*\.zip$', o):
            zipf = os.path.join(root, o)
            matches.append(zipf)
            
    return matches
開發者ID:charlesbrandt,項目名稱:medley,代碼行數:18,代碼來源:helpers.py

示例7: series

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import parent [as 別名]
def series(type="Image", relative=''):
    """
    show the current item in a series
    along with links to previous and next
    """
    global path_root

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

    path = Path(relative, relative_prefix=path_root)
    if path.type() != "Directory":
        parent = path.parent()
        parent_dir = parent.load()
        #parent_dir.sort_by_date()
        parent_dir.sort_by_path()
        parent_dir.scan_filetypes()
        if path.type() == "Image":
            count = 0
            position = None
            for i in parent_dir.images:
                if str(i) == str(path):
                    position = count
                    break
                count += 1

            if position is None:
                raise ValueError("Couldn't find matching image in directory: %s" % str(parent))
            else:
                if position != 0:
                    prev_pos = position-1
                else:
                    prev_pos = 0
                previous = parent_dir.images[prev_pos]

                nexts = []
                next_len = 5
                end = position + next_len
                if end >= len(parent_dir.images):
                    nexts = parent_dir.images[position+1:]
                else:
                    nexts = parent_dir.images[position+1:end]

                return template('series', path=path, parent=parent, previous=previous, nexts=nexts)
開發者ID:charlesbrandt,項目名稱:mindstream,代碼行數:48,代碼來源:application.py

示例8: make_json_path

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import parent [as 別名]
def make_json_path(item):

    name = ''
    parent = ''

    p = Path(item)
    if p.type() == "Directory":
        #item must be a directory... just look here
        parent = p
        name = p.name
    else:
        name = p.name
        #must be some other file type... load the parent directory:
        parent = p.parent()

    #making jsons named as tags to help normalize difficult characters
    json_name = "%s.json" % to_tag(name)
    #print json_name
    return os.path.join(str(parent), json_name)
開發者ID:charlesbrandt,項目名稱:medley,代碼行數:21,代碼來源:helpers.py

示例9: find_media

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

示例10: find_and_load_json

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

示例11: Timestamp

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import parent [as 別名]
    if translate is not None:
        (pre, post) = translate.split(':')
        matches = [ pre ]
    else:
        #can manually define here
        #(pre, post) = ('/c/binaries', '')
        ## matches = [ '/first/path/to/replace/', '/second/path/to/replace/' ]
        matches = ['/c/binaries', ]
        post = ''
    
    #for arg in sys.argv[1:]:

    # make new destination based on source
    now = Timestamp()
    spath = Path(source_name)
    parent = spath.parent()
    parts = spath.filename.split('-')
    new_parts = [ now.compact(accuracy="day") ]
    new_parts.extend(parts[1:])
    new_parts.insert(-1, "filtered")
    new_name = "-".join(new_parts)
    output = os.path.join(str(parent), new_name)
    print(output)
    #output = 'temp.m3u'

    source = file(source_name)
    destination = file(output, 'w')

    count = 0
    for line in source.readlines():
        for m in matches:
開發者ID:charlesbrandt,項目名稱:medley,代碼行數:33,代碼來源:filter_m3u_path.py

示例12: gaze_within

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import parent [as 別名]
def gaze_within(source):
    """
    at this point we know we have a local path (of some kind)...
    now we need to figure out what to do with it.

    depending on what we find at the path,
    we want to normalize the result into a list of json 'content' objects
    these should contain all of the information needed
    for displaying any of the variations of objects that may end up on a list
    name and default image are two of the most important

    this is where you will customize based on the type of list
    the inverse will be needed on the post route

    This is also the point where you will want to scan sources
    for anything new that is not in the list
    and add it to the front of the list (or however you want to handle that)

    may need to consider an import or convert process for some types
    in order to look up more information
    and make the necessary metadata (json) files
    e.g. convert a moments list to a list of content for a given time

    """
    sl = SortableList()
    contents = []
    current = None

    #TODO:
    #check for relative path here.. fill in the blanks as needed:
    if not re.match('/', source):
        raise ValueError("Don't know how to handle relative paths yet")

    path = Path(source)

    print(path.name)

    if path.type() == "Directory":

        current = scan_directory(path, sl, contents)

        #print item.directories

        #parent = item.path.parent()
        #print parent.name

    elif path.type() == "JSON":
        #could load it here... loop over each object
        pass

    elif path.type() == "List":
        #could load it here... loop over each object
        #however,
        #loading now happens as part of loading the path in scan_directory call
        #should choose one or the other
        #otherwise we end up with multiple copies of the list
        #if os.path.exists(source):
        #    sl.load(source)

        #now that the list has loaded, see if it's a list for the parent dir:

        if path.name == path.parent().name:
            current = scan_directory(path.parent(), sl, contents)
        else:
            #TODO
            #next option would be to look for a json file with the same name
            #if it exists, load that for content list
            print("%s != %s" % (path.name, path.parent().name))
            exit()


    else:
        #some other type of file...
        #load the parent directory in this case
        #and set this file to be the current content

        #this can be a time intensive way to calculate this,
        #especially if parent directory has a lot of children:
        current = scan_directory(path.parent(), sl, contents, path.filename)


    #print "Sortable List: %s" % (sl)
    #print "Contents: %s" % (contents)

    #go ahead and save the updated version
    #(e.g. any new files found during scan)
    if sl.source:
        sl.save()

    return (sl, contents, current)
開發者ID:charlesbrandt,項目名稱:sortable_list,代碼行數:92,代碼來源:gaze.py

示例13: sort

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

示例14: reparse

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import parent [as 別名]
    def reparse(self):
        """
        similar to rescan
        but this time go through and regenerate the individual json files
        for each content item
        from the original HTML source file

        this will utilize the customized Scraper IPlugin module
        for the given Collection

        typically this should be performed by the Scraper itself
        during content scans

        not sure how useful this will be
        other than to make sure integration of YAPSY is working
        """
        ## print "loading logging"
        ## import logging
        ## logging.basicConfig(level=logging.DEBUG)

        logging.debug("walking directory for reparse: %s" % self.root)
        html_check = re.compile('.*\.html$')
        #any directories that do not contain content should be listed here
        ignores = [ "pages", "archive" ]
        self_root_path = Path(self.root)
        parent = self_root_path.parent()

        #probably safe to assume this, but...
        if os.path.isdir(self.root):
            subdirs = self_root_path.load().directories
            for subdir in subdirs:
                if not check_ignore(str(subdir), ignores):
                    for root,dirs,files in os.walk(str(subdir)):
                        for f in files:
                            if html_check.search(f):
                                html_file = os.path.join(root, f)
                                print()
                                print()
                                print("Starting check of: %s" % html_file)

                                json = self.summary.scraper.parse_details(html_file)
                                self.summary.scraper.save_details(json, html_source=html_file)

                                #TODO:
                                #consider moving json saving into parse_details
                                #to avoid duplication of efforts
                                ## p_root = Path(html_file)
                                ## relative_root = p_root.to_relative(str(parent))
                                ## logging.debug("html relative path: %s" % relative_root)
                                ## #get rid of leading slash
                                ## relative_root = relative_root[1:]
                                ## json['root'] = relative_root
                                
                                ## if json.has_key('date'):
                                ##     ts = Timestamp(json['date'])
                                ## else:
                                ##     ts = Timestamp(f.split('.')[0])
                                ##     json['date'] = str(ts.compact(accuracy="day"))
                                ## json_path = os.path.join(root, ts.filename(".json"))
                                
                                ## save_json(json_path, json)

                                ## self.append(s)
                                #(or rescan)

        print("Finished parsing %s contents manually" % (len(self)))
        self.rescan()
開發者ID:charlesbrandt,項目名稱:medley,代碼行數:69,代碼來源:collector.py

示例15: rescan

# 需要導入模塊: from moments.path import Path [as 別名]
# 或者: from moments.path.Path import parent [as 別名]
    def rescan(self, ignores=[], debug=False):
        """
        look for all json files that describe the content items
        these should have been generated externally (e.g. during scrape)
        
        json files should contain the main attributes that a Content object has
        the rest will be kept in a remainder

        parsing html and generating json summaries of content
        is beyond the scope of this application
        and should be kept outside of this code base (too specific to content)
        """

        if not self.root:
            raise ValueError("Cannot rescan. No root set on collection: %s" % self.root)
        
        #clear out anything else
        del self[:]

        if debug:
            print("walking directory for contents: %s" % self.root)

        json_check = re.compile('.*\.json$')

        #it might be inefficient to try to define these here...
        #too many different names that might work in different contexts
        #ignores = ["contents", "collection", "incompletes"]
        #can pass them in if needed...
        
        self_root_path = Path(self.root)
        parent = self_root_path.parent()
        if not os.path.isdir(self.root):
            print("Looking for path of root: %s" % self.root)
            print("(is the drive mounted???)")
            self.root = os.path.dirname(self.root)
            #if we still don't have a directory, something is wrong with root
            assert os.path.isdir(self.root)

        
        #instead of looking for ignores
        #will limit by convention
        #top level directory should only contain meta jsons
        #(that should be ignored as content data)
        #content jsons will always be in a subdirectory
        #similarly, meta jsons should never be in a subdirectory

        #for root,dirs,files in os.walk(self.root):
        subdirs = self_root_path.load().directories
        for subdir in subdirs:
            if check_ignore(str(subdir), ignores):
                print("Ignoring directory: %s" % (subdir))
            else:
                for root,dirs,files in os.walk(str(subdir)):
                    for f in files:

                        #if json_check.search(f):
                        if json_check.search(f) and not check_ignore(f, ignores):
                            json_file = os.path.join(root, f)
                            p_root = Path(root)
                            relative_root = p_root.to_relative(str(parent))
                            #get rid of leading slash
                            if re.match('/', relative_root):
                                relative_root = relative_root[1:]
                            if debug:
                                print("loading content from: %s" % json_file)
                            #c = Content(json_file, root=relative_root)
                            c = Content(json_file)
                            if debug:
                                print("setting base_dir to: %s" % relative_root)

                            #if updating one here, should update the other:
                            c.base_dir = relative_root
                            c.drive_dir = str(parent)

                            self.append(c)

        if debug:
            print("Finished loading %s contents manually" % (len(self)))
開發者ID:charlesbrandt,項目名稱:medley,代碼行數:80,代碼來源:collector.py


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