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


Python File.filename方法代碼示例

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


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

示例1: testBlobbableOFSFile

# 需要導入模塊: from OFS.Image import File [as 別名]
# 或者: from OFS.Image.File import filename [as 別名]
 def testBlobbableOFSFile(self):
     obj = File('foo', 'Foo', getFile('plone.pdf'), 'application/pdf')
     obj.filename = 'foo.pdf'
     blobbable = IBlobbable(obj)
     target = Blob()
     blobbable.feed(target)
     self.assertEqual(target.open('r').read(),
         getFile('plone.pdf').read())
     self.assertEqual(blobbable.filename(), 'foo.pdf')
     self.assertEqual(blobbable.mimetype(), 'application/pdf')
開發者ID:CGTIC,項目名稱:Plone_SP,代碼行數:12,代碼來源:test_adapters.py

示例2: test_uploadFile

# 需要導入模塊: from OFS.Image import File [as 別名]
# 或者: from OFS.Image.File import filename [as 別名]
    def test_uploadFile(self):
        file = File('foo', 'Foo', getFile('plone.pdf'), 'application/pdf')
        file.filename = 'foo.pdf'

        myUpload = makeFileUpload(file, 'test.gif')
        myUpload.method = 'GET'
        view = VNCCollabUtilView(self.portal, myUpload)
        self.assertRaises(Exception, lambda:  view.uploadFile(myUpload))

        myUpload = makeFileUpload(file, 'test.gif')
        myUpload.method = 'POST'
        myUpload.form = {}
        headers, output, request = makeResponse(myUpload)
        view = VNCCollabUtilView(self.portal, request)
        result = view.uploadFile(file)
        self.assertEqual(result, 'http://nohost/plone/foo.pdf/edit')

        myUpload = makeFileUpload(file, 'test.gif')
        myUpload.method = 'POST'
        myUpload.form = {'ajax_call': True}
        headers, output, request = makeResponse(myUpload)
        view = VNCCollabUtilView(self.portal, request)
        result = view.uploadFile(file)
        self.assertEqual(result, 'http://nohost/plone/foo.pdf-1/edit')
開發者ID:giacomos,項目名稱:vnccollab.theme,代碼行數:26,代碼來源:test_util_view.py

示例3: open

# 需要導入模塊: from OFS.Image import File [as 別名]
# 或者: from OFS.Image.File import filename [as 別名]
try:
    proxy.invokeFactory('Section', 'test-folder')
except xmlrpclib.ProtocolError:
    print sys.exc_info()[1]
except xmlrpclib.Fault:
    print "The id is invalid - it is already in use."  # most likely
proxy = xmlrpclib.ServerProxy(url + '/test-folder')
proxy.setTitle('Test folder')
proxy.setDescription('This is a test folder')

# create image
proxy = xmlrpclib.ServerProxy(url)  # reset
#wrappedData = xmlrpclib.Binary(open('screenshot.png').read())
filename = 'screenshot.png'
data = open(filename).read()
fileData = File(filename, filename, data, 'application/octet-stream')
fileData.filename = filename
wrappedData = fileData
try:
    proxy.invokeFactory('Image', 'screenshot.png')
except xmlrpclib.ProtocolError:
    print sys.exc_info()[1]
except xmlrpclib.Fault:
    print "The id is invalid - it is already in use."  # most likely
proxy = xmlrpclib.ServerProxy(url + '/screenshot.png')
proxy.setTitle('This is an image')
try:
    proxy.setImage(wrappedData)  # XXX this fails
except:
    print sys.exc_info()[1]
開發者ID:aclarktest,項目名稱:xmlrpc_setimage_wtf,代碼行數:32,代碼來源:wtf.py

示例4: __iter__

# 需要導入模塊: from OFS.Image import File [as 別名]
# 或者: from OFS.Image.File import filename [as 別名]
    def __iter__(self):
        
        for item in self.previous:
            yield item
        
        metadata = {}
        
        if self.metadata:
            metadataFile = open(self.metadata, 'rb')
            reader = csv.DictReader(metadataFile, delimiter=self.delimiter)

            if reader.fieldnames is None:
                raise ValueError("Metadata CSV is empty.")
            if len(reader.fieldnames) is 1 and self.delimiter not in reader.fieldnames[0]:
                raise ValueError("Metadata CSV does not use the specified delimiter: %s" %(self.delimiter))
            if 'path' not in reader.fieldnames:
                raise ValueError("Metadata CSV file does not have a 'path' column.")

            if self.strict:
                field_count = len(reader.fieldnames)
            
            for row in reader:
                
                if self.strict and field_count != len(row):
                    raise ValueError("Found a row in Metadata CSV that has a different count of fields \
                        compared to first row: %s" %(row))
                
                path = row['path']
                data = row.copy()
                del data['path']
                metadata[path] = data
        
        if self.requireMetadata and not metadata:
            raise ValueError("Metadata is required, but metadata file %s not given or empty" % self.metadata)
        
        if not os.path.exists(self.directory):
            raise ValueError("Directory %s does not exist" % self.directory)

        for dirpath, dirnames, filenames in os.walk(self.directory):
            wrapData = self.wrapData
            # Create folders first, if necessary
            for dirname in dirnames:
                dirPath = os.path.join(dirpath, dirname)
                zodbPath = self.getZODBPath(dirPath)
                
                if self.ignored(zodbPath)[1]:
                    continue
                
                _type = self.folderType
                
                item = {'_type': self.folderType,
                        '_path': zodbPath}
                
                if zodbPath in metadata:
                    item.update(metadata[zodbPath])
                
                yield item
            
            # Then import files
            for filename in filenames:
                filePath = os.path.join(dirpath, filename)
                zodbPath = self.getZODBPath(filePath)
                
                if self.ignored(zodbPath)[1]:
                    continue
                
                if self.metadata and os.path.abspath(filePath) == os.path.abspath(self.metadata):
                    continue
                
                if self.requireMetadata and zodbPath not in metadata:
                    continue

                if zodbPath in metadata and 'portal_type' in metadata[zodbPath] and \
                   metadata[zodbPath]['portal_type'] in ['News Item', 'Document', 'Event']:
                    # if portal_type is given in metadata.csv, use it!
                    _type = metadata[zodbPath]['portal_type']

                    mimeType = 'text/html'
                    fieldname = 'text'
                    wrapData = False
                    #if the file is an image: use the image field of the news item, otherwise use the text field
                    if _type == 'News Item':
                        basename, extension = os.path.splitext(filename)
                        if extension and extension.lower() in mimetypes.types_map and mimetypes.types_map[extension.lower()].startswith('image'):
                            mimeType = mimetypes.types_map[extension.lower()]
                            fieldname = self.imageField # the same of news
                            wrapData = self.wrapData

                else:                
                    # else make it File or Image
                    _type = self.fileType
                    fieldname = self.fileField  
                    mimeType = self.defaultMimeType
                                  
                    # Try to guess mime type and content type
                    basename, extension = os.path.splitext(filename)
                    if extension and extension.lower() in mimetypes.types_map:
                        mimeType = mimetypes.types_map[extension.lower()]
                        if mimeType.startswith('image'):
                            _type = self.imageType
#.........這裏部分代碼省略.........
開發者ID:redomino,項目名稱:transmogrify.filesystem,代碼行數:103,代碼來源:source.py

示例5: sync_contacts

# 需要導入模塊: from OFS.Image import File [as 別名]
# 或者: from OFS.Image.File import filename [as 別名]
def sync_contacts(context, ldap_records, set_owner=False):
    """Synchronize the given ldap results """

    # Statistics
    created = 0
    modified = 0
    skipped = 0
    failed = 0
    deleted = 0

    dn_contact_id_mapping = {}

    ct = getToolByName(context, 'portal_catalog')
    mapper = get_ldap_attribute_mapper()
    dummy_contact = createContent('ftw.contacts.Contact')
    dummy_contact_folder = createContent('ftw.contacts.ContactFolder')

    # 1st pass: create or update profiles
    for dn, entry in ldap_records:

        if not dn:
            continue

        dn = dn.decode('unicode_escape').encode('iso8859-1').decode('utf-8')

        # Only entries with a contact id
        contact_id = entry.get(mapper.id(), [None, ])[0]
        if not contact_id:
            skipped += 1
            logger.debug("Skipping entry '%s'. No contact id." % dn)
            continue
        # Get the normalzied name for the contact with the given id. This has
        # to be done on a dummy folder because existing content would influence
        # the resulting id.
        contact_id = INameChooser(dummy_contact_folder).chooseName(
            contact_id, dummy_contact)

        dn_contact_id_mapping[dn] = contact_id

        contact = context.unrestrictedTraverse(contact_id, None)
        changed = False
        is_new_object = False

        # Check if we really got the wanted object.
        if not IContact.providedBy(contact):
            contact = None

        # Create contact
        if contact is None:
            try:
                contact = createContent('ftw.contacts.Contact')
                contact.id = contact_id
                addContentToContainer(context, contact)

                is_new_object = True
            # invalid id
            except BadRequest:
                failed += 1
                logger.warn("Could not create contact '%s' (invalid id)."
                            % contact_id)
                continue

        # Update/set field values
        IContactSchema(contact).ldap_dn = dn
        field_mapping = dict(getFields(IContactSchema))
        for ldap_name, field_name in mapper.mapping().items():
            field = field_mapping.get(field_name, None)
            if field is None:
                raise NotImplementedError()

            value = entry.get(ldap_name, [''])[0]

            current_value = field.get(contact)
            if IBlobWrapper.providedBy(current_value):
                current_value = current_value.data

            if current_value != value:
                # Handle images
                if INamedImageField.providedBy(field) and value:
                    infile = StringIO(value)
                    filename = '%s.jpg' % contact_id
                    value = File(filename, filename, infile, 'image/jpeg')
                    value.filename = filename

                field.set(contact, value)
                changed = True

        # Update/set fields with custom updaters
        custom_updaters = getAdapters((contact, entry),
                                      provided=ILDAPCustomUpdater)
        for name, updater in custom_updaters:
            changed = updater.update()

        if is_new_object:
            if set_owner:
                # Grant owner role to contact
                contact.__ac_local_roles__ = None
                contact.manage_setLocalRoles(contact_id, ['Owner'])
                contact.reindexObjectSecurity()

#.........這裏部分代碼省略.........
開發者ID:4teamwork,項目名稱:ftw.contacts,代碼行數:103,代碼來源:sync.py


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