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


Python storage.FileSystemStorage方法代碼示例

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


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

示例1: image_upload

# 需要導入模塊: from django.core.files import storage [as 別名]
# 或者: from django.core.files.storage import FileSystemStorage [as 別名]
def image_upload(request):
    if request.method == 'POST':
        image_file = request.FILES['image_file']
        image_type = request.POST['image_type']
        if settings.USE_S3:
            if image_type == 'private':
                upload = UploadPrivate(file=image_file)
            else:
                upload = Upload(file=image_file)
            upload.save()
            image_url = upload.file.url
        else:
            fs = FileSystemStorage()
            filename = fs.save(image_file.name, image_file)
            image_url = fs.url(filename)
        return render(request, 'upload.html', {
            'image_url': image_url
        })
    return render(request, 'upload.html') 
開發者ID:testdrivenio,項目名稱:django-docker-s3,代碼行數:21,代碼來源:views.py

示例2: image_upload

# 需要導入模塊: from django.core.files import storage [as 別名]
# 或者: from django.core.files.storage import FileSystemStorage [as 別名]
def image_upload(request):
    pytitionuser = get_session_user(request)

    if request.method != "POST":
        return HttpResponseForbidden()

    file = request.FILES.get('file', '')
    if file == '':
        return HttpResponseForbidden()

    storage = FileSystemStorage()
    path = os.path.join(storage.location, pytitionuser.username, file.name)
    name = storage._save(path, file)
    newrelpath = os.path.relpath(name, storage.location)

    return JsonResponse({'location': storage.base_url + newrelpath})

# /transfer_petition/<int:petition_id>
# Transfer a petition to another org or user 
開發者ID:pytition,項目名稱:Pytition,代碼行數:21,代碼來源:views.py

示例3: test_del_tmp_upload_file

# 需要導入模塊: from django.core.files import storage [as 別名]
# 或者: from django.core.files.storage import FileSystemStorage [as 別名]
def test_del_tmp_upload_file(self):
        # Create a temporary file
        tmp_dir = mkdtemp(prefix='django_test_')
        self.assertTrue(os.path.exists(tmp_dir),
                        'Test temp file was not created.')
        tmp_dir_split = tmp_dir.rsplit(os.sep, 1)
        _, path = mkstemp(suffix='.txt', prefix='django_test_', text=True)
        self.assertTrue(os.path.exists(path),
                        'Test temp file was not created.')

        # Mock a TemporaryUpload instance object
        tu = Mock(spec=TemporaryUpload)
        upload_file = Mock(spec=SimpleUploadedFile)
        models.storage = Mock(spec=FileSystemStorage)
        models.storage.location = tmp_dir_split[0]

        upload_file.path = path
        tu.upload_id = tmp_dir_split[1]
        tu.file = upload_file
        delete_temp_upload_file(None, tu)
        self.assertFalse(os.path.exists(path), 'Test temp file was not '
                         'removed by the signal handler.') 
開發者ID:ImperialCollegeLondon,項目名稱:django-drf-filepond,代碼行數:24,代碼來源:test_signals.py

示例4: test_process_invalid_storage_location

# 需要導入模塊: from django.core.files import storage [as 別名]
# 或者: from django.core.files.storage import FileSystemStorage [as 別名]
def test_process_invalid_storage_location(self):
        old_storage = views.storage
        views.storage = FileSystemStorage(location='/django_test')
        (encoded_form, content_type) = self._get_encoded_form('testfile.dat')

        rf = RequestFactory()
        req = rf.post(reverse('process'),
                      data=encoded_form, content_type=content_type)
        pv = views.ProcessView.as_view()
        response = pv(req)
        views.storage = old_storage
        self.assertEqual(response.status_code, 500, 'Expecting 500 error due'
                         ' to invalid storage location.')
        self.assertEqual(
            response.data,
            'The file upload path settings are not configured correctly.',
            ('Expecting error showing path settings are configured '
             'incorrectly.')) 
開發者ID:ImperialCollegeLondon,項目名稱:django-drf-filepond,代碼行數:20,代碼來源:test_process_view.py

示例5: test_store_upload_with_storage_outside_BASE_DIR_without_enable

# 需要導入模塊: from django.core.files import storage [as 別名]
# 或者: from django.core.files.storage import FileSystemStorage [as 別名]
def test_store_upload_with_storage_outside_BASE_DIR_without_enable(self):
        old_storage = views.storage
        views.storage = FileSystemStorage(location='/tmp/uploads')
        (encoded_form, content_type) = self._get_encoded_form('testfile.dat')

        rf = RequestFactory()
        req = rf.post(reverse('process'),
                      data=encoded_form, content_type=content_type)
        pv = views.ProcessView.as_view()
        response = pv(req)
        views.storage = old_storage
        self.assertEqual(response.status_code, 500, 'Expecting 500 error due'
                         ' to invalid storage location.')
        self.assertEqual(
            response.data,
            'The file upload path settings are not configured correctly.',
            ('Expecting error showing path settings are configured '
             'incorrectly.')) 
開發者ID:ImperialCollegeLondon,項目名稱:django-drf-filepond,代碼行數:20,代碼來源:test_process_view.py

示例6: test_store_upload_with_storage_outside_BASE_DIR_with_enable

# 需要導入模塊: from django.core.files import storage [as 別名]
# 或者: from django.core.files.storage import FileSystemStorage [as 別名]
def test_store_upload_with_storage_outside_BASE_DIR_with_enable(self):
        old_storage = views.storage
        old_UPLOAD_TMP = drf_filepond_settings.UPLOAD_TMP

        drf_filepond_settings.ALLOW_EXTERNAL_UPLOAD_DIR = True

        views.storage = FileSystemStorage(location='/tmp/uploads')
        drf_filepond_settings.UPLOAD_TMP = '/tmp/uploads'

        (encoded_form, content_type) = self._get_encoded_form('testfile.dat')

        rf = RequestFactory()
        req = rf.post(reverse('process'),
                      data=encoded_form, content_type=content_type)
        pv = views.ProcessView.as_view()
        response = pv(req)
        views.storage = old_storage
        drf_filepond_settings.UPLOAD_TMP = old_UPLOAD_TMP
        drf_filepond_settings.ALLOW_EXTERNAL_UPLOAD_DIR = False
        self.assertEqual(response.status_code, 200, 'Expecting upload to be '
                         'successful.') 
開發者ID:ImperialCollegeLondon,項目名稱:django-drf-filepond,代碼行數:23,代碼來源:test_process_view.py

示例7: enqueue_image

# 需要導入模塊: from django.core.files import storage [as 別名]
# 或者: from django.core.files.storage import FileSystemStorage [as 別名]
def enqueue_image(person, user, image_url):
    r = requests.get(
        image_url,
        headers={
            'User-Agent': USER_AGENT,
        },
        stream=True
    )
    if not r.status_code == 200:
        message = "HTTP status code {0} when downloading {1}"
        raise Exception(message.format(r.status_code, image_url))
    storage = FileSystemStorage()
    suggested_filename = \
        'queued_image/{d.year}/{d.month:02x}/{d.day:02x}/ci-upload'.format(
            d=date.today()
        )
    storage_filename = storage.save(suggested_filename, r.raw)
    QueuedImage.objects.create(
        why_allowed=QueuedImage.OTHER,
        justification_for_use="Downloaded from {0}".format(image_url),
        decision=QueuedImage.UNDECIDED,
        image=storage_filename,
        person_id=person.id,
        user=user
    ) 
開發者ID:mysociety,項目名稱:yournextrepresentative,代碼行數:27,代碼來源:ar_elections_2015_import_candidates.py

示例8: __init__

# 需要導入模塊: from django.core.files import storage [as 別名]
# 或者: from django.core.files.storage import FileSystemStorage [as 別名]
def __init__(self):
        # get all registered apps

        self.locations = []
        self.storages = OrderedDict()

        self.ignore_patterns = ["*.py", "*.pyc",]

        for app_config in apps.get_app_configs():

            path_directory = os.path.join(app_config.path, 'assets')

            if os.path.isdir(path_directory):

                storage = FileSystemStorage(location=path_directory)

                storage.prefix = full_asset_path(app_config.name, "")

                self.locations.append(app_config.name)
                self.storages[app_config.name] = storage

        super(DashAppDirectoryFinder, self).__init__()

    #pylint: disable=redefined-builtin 
開發者ID:GibbsConsulting,項目名稱:django-plotly-dash,代碼行數:26,代碼來源:finders.py

示例9: project_upload

# 需要導入模塊: from django.core.files import storage [as 別名]
# 或者: from django.core.files.storage import FileSystemStorage [as 別名]
def project_upload(request):
    """
    upload project
    :param request: request object
    :return: json
    """
    if request.method == 'POST':
        file = request.FILES['file']
        file_name = file.name
        fs = FileSystemStorage(PROJECTS_FOLDER)
        zip_file_name = fs.save(file_name, file)
        logger.debug('zip file name %s', zip_file_name)
        # extract zip file
        with zipfile.ZipFile(join(PROJECTS_FOLDER, zip_file_name), 'r') as zip_ref:
            zip_ref.extractall(PROJECTS_FOLDER)
        logger.debug('extracted files to %s', PROJECTS_FOLDER)
        return JsonResponse({'status': True}) 
開發者ID:Gerapy,項目名稱:Gerapy,代碼行數:19,代碼來源:views.py

示例10: __init__

# 需要導入模塊: from django.core.files import storage [as 別名]
# 或者: from django.core.files.storage import FileSystemStorage [as 別名]
def __init__(self, location=None, base_url=None, *args, **kwargs):
        if location is None:
            location = settings.STATIC_ROOT
        if base_url is None:
            base_url = settings.STATIC_URL
        check_settings(base_url)
        super(StaticFilesStorage, self).__init__(location, base_url,
                                                 *args, **kwargs)
        # FileSystemStorage fallbacks to MEDIA_ROOT when location
        # is empty, so we restore the empty value.
        if not location:
            self.base_location = None
            self.location = None 
開發者ID:lanbing510,項目名稱:GTDWeb,代碼行數:15,代碼來源:storage.py

示例11: is_local_storage

# 需要導入模塊: from django.core.files import storage [as 別名]
# 或者: from django.core.files.storage import FileSystemStorage [as 別名]
def is_local_storage(self):
        return isinstance(self.storage, FileSystemStorage) 
開發者ID:lanbing510,項目名稱:GTDWeb,代碼行數:4,代碼來源:collectstatic.py

示例12: export_download

# 需要導入模塊: from django.core.files import storage [as 別名]
# 或者: from django.core.files.storage import FileSystemStorage [as 別名]
def export_download(request, username, id_string, export_type, filename):
    owner = get_object_or_404(User, username__iexact=username)
    xform = get_object_or_404(XForm, id_string__exact=id_string, user=owner)
    helper_auth_helper(request)
    if not has_forms_permission(xform, owner, request):
        return HttpResponseForbidden(_(u'Not shared.'))

    # find the export entry in the db
    export = get_object_or_404(Export, xform=xform, filename=filename)

    if (export_type == Export.GDOC_EXPORT or export_type == Export.EXTERNAL_EXPORT) \
            and export.export_url is not None:
        return HttpResponseRedirect(export.export_url)

    ext, mime_type = export_def_from_filename(export.filename)

    audit = {
        "xform": xform.id_string,
        "export_type": export.export_type
    }
    audit_log(
        Actions.EXPORT_DOWNLOADED, request.user, owner,
        _("Downloaded %(export_type)s export '%(filename)s' "
          "on '%(id_string)s'.") %
        {
            'export_type': export.export_type.upper(),
            'filename': export.filename,
            'id_string': xform.id_string,
        }, audit, request)
    if request.GET.get('raw'):
        id_string = None

    default_storage = get_storage_class()()
    if not isinstance(default_storage, FileSystemStorage):
        return HttpResponseRedirect(default_storage.url(export.filepath))
    basename = os.path.splitext(export.filename)[0]
    response = response_with_mimetype_and_name(
        mime_type, name=basename, extension=ext,
        file_path=export.filepath, show_date=False)
    return response 
開發者ID:awemulya,項目名稱:kobo-predict,代碼行數:42,代碼來源:views.py

示例13: __init__

# 需要導入模塊: from django.core.files import storage [as 別名]
# 或者: from django.core.files.storage import FileSystemStorage [as 別名]
def __init__(self, location=None, base_url=None, *args, **kwargs):
        if location is None:
            location = settings.STATIC_ROOT
        if base_url is None:
            base_url = settings.STATIC_URL
        check_settings(base_url)
        super().__init__(location, base_url, *args, **kwargs)
        # FileSystemStorage fallbacks to MEDIA_ROOT when location
        # is empty, so we restore the empty value.
        if not location:
            self.base_location = None
            self.location = None 
開發者ID:reBiocoder,項目名稱:bioforum,代碼行數:14,代碼來源:storage.py

示例14: delete_file

# 需要導入模塊: from django.core.files import storage [as 別名]
# 或者: from django.core.files.storage import FileSystemStorage [as 別名]
def delete_file(self, request, **kwargs):
        """
        Delete a file from session\n
            Params:
                - filename: str
        """
        session_id = self.get_object().pk
        file_name = request.POST.get('filename')

        if not file_name:
            raise APIException('Provide a file name.')

        try:
            storage = FileSystemStorage(
                location=os.path.join(
                    settings.MEDIA_ROOT,
                    settings.FILEBROWSER_DOCUMENTS_DIRECTORY,
                    session_id))

            if storage.exists(file_name):
                storage.delete(file_name)
                file_tasks = Task.objects \
                    .filter(metadata__session_id=session_id) \
                    .filter(metadata__file_name=file_name)
                for file_task in file_tasks:
                    if file_task.metadata.get('file_name') == file_name:
                        purge_task(file_task.id)
                Document.objects \
                    .filter(upload_session_id=session_id, name=file_name) \
                    .delete()
                return Response('Deleted')
            raise APIException("File doesn't exist")

        except Exception as e:
            raise APIException(str(e))


# --------------------------------------------------------
# Project Clustering Views
# -------------------------------------------------------- 
開發者ID:LexPredict,項目名稱:lexpredict-contraxsuite,代碼行數:42,代碼來源:v1.py

示例15: __init__

# 需要導入模塊: from django.core.files import storage [as 別名]
# 或者: from django.core.files.storage import FileSystemStorage [as 別名]
def __init__(self, *args, **kwargs):
        self.wrapped = FileSystemStorage(*args, **kwargs) 
開發者ID:wagtail,項目名稱:wagtail,代碼行數:4,代碼來源:dummy_external_storage.py


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