mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #13040 -- Added info on where to import File class from to File reference docs, and improved Sphinx formatting. Thanks to stherrien for the report.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@14339 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -3,100 +3,106 @@ The ``File`` object | |||||||
|  |  | ||||||
| .. currentmodule:: django.core.files | .. currentmodule:: django.core.files | ||||||
|  |  | ||||||
| .. class:: File(file_object) |  | ||||||
|  |  | ||||||
| ``File`` attributes and methods | ``File`` attributes and methods | ||||||
| ------------------------------- | ------------------------------- | ||||||
|  |  | ||||||
| Django's ``File`` has the following attributes and methods: | The :mod:`django.core.files` module contains a built-in class for basic file | ||||||
|  | handling in Django. The :class:`File` class has the following attributes and | ||||||
|  | methods: | ||||||
|  |  | ||||||
| .. attribute:: File.name | .. class:: File(file_object) | ||||||
|  |  | ||||||
|     The name of file including the relative path from :setting:`MEDIA_ROOT`. |     .. attribute:: name | ||||||
|  |  | ||||||
| .. attribute:: File.path |         The name of file including the relative path from :setting:`MEDIA_ROOT`. | ||||||
|  |  | ||||||
|     The absolute path to the file's location on a local filesystem. |     .. attribute:: path | ||||||
|  |  | ||||||
|     :doc:`Custom file storage systems </howto/custom-file-storage>` may not store |         The absolute path to the file's location on a local filesystem. | ||||||
|     files locally; files stored on these systems will have a ``path`` of |  | ||||||
|     ``None``. |  | ||||||
|  |  | ||||||
| .. attribute:: File.url |         :doc:`Custom file storage systems </howto/custom-file-storage>` may not store | ||||||
|  |         files locally; files stored on these systems will have a ``path`` of | ||||||
|  |         ``None``. | ||||||
|  |  | ||||||
|     The URL where the file can be retrieved. This is often useful in |     .. attribute:: url | ||||||
|     :doc:`templates </topics/templates>`; for example, a bit of a template for |  | ||||||
|     displaying a ``Car`` (see above) might look like: |  | ||||||
|  |  | ||||||
|     .. code-block:: html+django |         The URL where the file can be retrieved. This is often useful in | ||||||
|  |         :doc:`templates </topics/templates>`; for example, a bit of a template for | ||||||
|  |         displaying a ``Car`` (see above) might look like: | ||||||
|          |          | ||||||
|         <img src='{{ car.photo.url }}' alt='{{ car.name }}' /> |         .. code-block:: html+django | ||||||
|  |  | ||||||
| .. attribute:: File.size |             <img src='{{ car.photo.url }}' alt='{{ car.name }}' /> | ||||||
|  |  | ||||||
|     The size of the file in bytes. |     .. attribute:: size | ||||||
|  |  | ||||||
| .. method:: File.open(mode=None) |         The size of the file in bytes. | ||||||
|  |  | ||||||
|     Open or reopen the file (which by definition also does ``File.seek(0)``). |     .. method:: open([mode=None]) | ||||||
|     The ``mode`` argument allows the same values as Python's standard |  | ||||||
|     ``open()``. |  | ||||||
|  |  | ||||||
|     When reopening a file, ``mode`` will override whatever mode the file was |         Open or reopen the file (which by definition also does ``File.seek(0)``). | ||||||
|     originally opened with; ``None`` means to reopen with the original mode. |         The ``mode`` argument allows the same values as Python's standard | ||||||
|  |         ``open()``. | ||||||
|  |  | ||||||
| .. method:: File.read(num_bytes=None) |         When reopening a file, ``mode`` will override whatever mode the file was | ||||||
|  |         originally opened with; ``None`` means to reopen with the original mode. | ||||||
|  |  | ||||||
|     Read content from the file. The optional ``size`` is the number of bytes to |     .. method:: read([num_bytes=None]) | ||||||
|     read; if not specified, the file will be read to the end. |  | ||||||
|  |  | ||||||
| .. method:: File.__iter__() |         Read content from the file. The optional ``size`` is the number of bytes to | ||||||
|  |         read; if not specified, the file will be read to the end. | ||||||
|  |  | ||||||
|     Iterate over the file yielding one line at a time. |     .. method:: __iter__() | ||||||
|  |  | ||||||
| .. method:: File.chunks(chunk_size=None) |         Iterate over the file yielding one line at a time. | ||||||
|  |  | ||||||
|     Iterate over the file yielding "chunks" of a given size. ``chunk_size`` |     .. method:: chunks([chunk_size=None]) | ||||||
|     defaults to 64 KB. |  | ||||||
|  |  | ||||||
|     This is especially useful with very large files since it allows them to be |         Iterate over the file yielding "chunks" of a given size. ``chunk_size`` | ||||||
|     streamed off disk and avoids storing the whole file in memory. |         defaults to 64 KB. | ||||||
|  |  | ||||||
| .. method:: File.multiple_chunks(chunk_size=None) |         This is especially useful with very large files since it allows them to be | ||||||
|  |         streamed off disk and avoids storing the whole file in memory. | ||||||
|  |  | ||||||
|     Returns ``True`` if the file is large enough to require multiple chunks to |     .. method:: multiple_chunks([chunk_size=None]) | ||||||
|     access all of its content give some ``chunk_size``. |  | ||||||
|  |  | ||||||
| .. method:: File.write(content) |         Returns ``True`` if the file is large enough to require multiple chunks to | ||||||
|  |         access all of its content give some ``chunk_size``. | ||||||
|  |  | ||||||
|     Writes the specified content string to the file. Depending on the storage |     .. method:: write([content]) | ||||||
|     system behind the scenes, this content might not be fully committed until |  | ||||||
|     ``close()`` is called on the file. |  | ||||||
|  |  | ||||||
| .. method:: File.close() |         Writes the specified content string to the file. Depending on the storage | ||||||
|  |         system behind the scenes, this content might not be fully committed until | ||||||
|  |         ``close()`` is called on the file. | ||||||
|  |  | ||||||
|     Close the file. |     .. method:: close() | ||||||
|  |  | ||||||
|  |         Close the file. | ||||||
|  |  | ||||||
|  | .. currentmodule:: django.core.files.images | ||||||
|  |  | ||||||
| Additional ``ImageField`` attributes | Additional ``ImageField`` attributes | ||||||
| ------------------------------------ | ------------------------------------ | ||||||
|  |  | ||||||
| .. attribute:: File.width | .. class:: ImageFile(file_object) | ||||||
|  |  | ||||||
|     Width of the image. |     .. attribute:: width | ||||||
|          |          | ||||||
| .. attribute:: File.height |         Width of the image. | ||||||
|  |  | ||||||
|     Height of the image. |     .. attribute:: height | ||||||
|  |  | ||||||
|  |         Height of the image. | ||||||
|  |  | ||||||
|  | .. currentmodule:: django.core.files | ||||||
|  |  | ||||||
| Additional methods on files attached to objects | Additional methods on files attached to objects | ||||||
| ----------------------------------------------- | ----------------------------------------------- | ||||||
|  |  | ||||||
| .. highlight:: pycon |  | ||||||
|  |  | ||||||
| Any :class:`File` that's associated with an object (as with ``Car.photo``, | Any :class:`File` that's associated with an object (as with ``Car.photo``, | ||||||
| above) will also have a couple of extra methods: | above) will also have a couple of extra methods: | ||||||
|  |  | ||||||
| .. method:: File.save(name, content, save=True) | .. method:: File.save(name, content, [save=True]) | ||||||
|  |  | ||||||
|     Saves a new file with the file name and contents provided. This will not |     Saves a new file with the file name and contents provided. This will not | ||||||
|     replace the existing file, but will create a new file and update the object |     replace the existing file, but will create a new file and update the object | ||||||
| @@ -113,7 +119,7 @@ above) will also have a couple of extra methods: | |||||||
|     Note that the ``content`` argument must be an instance of |     Note that the ``content`` argument must be an instance of | ||||||
|     :class:`File` or of a subclass of :class:`File`. |     :class:`File` or of a subclass of :class:`File`. | ||||||
|  |  | ||||||
| .. method:: File.delete(save=True) | .. method:: File.delete([save=True]) | ||||||
|  |  | ||||||
|     Remove the file from the model instance and delete the underlying file. The |     Remove the file from the model instance and delete the underlying file. The | ||||||
|     ``save`` argument works as above. |     ``save`` argument works as above. | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user