Shows how to create, read, write, copy and delete a file, how to retrieve file properties, and how to track a file or folder so that your app can access it again. This sample uses the Windows.Storage and Windows.Storage.AccessCache APIs.
Note: This sample is part of a large collection of UWP feature samples. If you are unfamiliar with Git and GitHub, you can download the entire collection as a ZIP file, but be sure to unzip everything to access shared dependencies. For more info on working with the ZIP file, the samples collection, and GitHub, see Get the UWP samples from GitHub. For more samples, see the Samples portal on the Windows Dev Center.
The sample demonstrates these tasks:
-
Create a file in the Pictures library
Uses one of the StorageFolder.CreateFileAsync methods to create the file.
-
Get a file's parent folder
Uses the StorageFile.GetParentAsync method to get the parent folder of the file that was created in the Picture folder. The app has the Pictures library capability, so it can access the folder where the file was created.
-
Write and read text in a file
Uses the FileIO.WriteTextAsync and FileIO.ReadTextAsync methods to write and read the file. For more info, see Create, write, and read a file.
-
Write and read bytes in a file
Uses the FileIO.WriteBufferAsync and FileIO.ReadBufferAsync methods to write and read the file. For more info, see Create, write, and read a file.
-
Write and read a file using a stream
Uses the following API to write and read the file using a stream.
- StorageFile.OpenTransactedWriteAsync method
- DataWriter class
- DataReader class
For more info, see Create, write, and read a file.
-
Display file properties
Uses the StorageFile.GetBasicPropertiesAsync method and the StorageFile.Properties property to get the properties of the file.
-
Track a file or folder so that you can access it later (persisting access)
Uses the StorageApplicationPermissions.FutureAccessList and StorageApplicationPermissions.MostRecentlyUsedList properties to remember a file or folder so that it can be accessed later.
For more info, see Track recently used files and folders.
-
Copy a file
Uses one of the StorageFile.CopyAsync methods to copy the file.
-
Compare two files to see if they're the same
Uses the StorageFile.IsEqual method to compare two files.
-
Delete a file
Uses one of the StorageFile.DeleteAsync methods to delete the file.
-
Try to get a file without getting an error
Uses the StorageFolder.TryGetItemAsync method to get a file without raising an exception.
Note The Windows universal samples require Visual Studio 2017 to build and Windows 10 to execute.
To obtain information about Windows 10 development, go to the Windows Dev Center
To obtain information about Microsoft Visual Studio and the tools for developing Windows apps, go to Visual Studio
Note* If you want to learn about accessing files using a file picker, see Open files and folders with a picker.
File picker sample
Folder enumeration sample
Programmatic file search sample
File and folder thumbnail sample
RSS reader sample
Family Notes sample
Coloring Book app sample
Traffic App sample
Windows.Storage namespace
Windows.Storage.AccessCache namespace
Windows.Storage.FileProperties
Windows.Storage.Streams namespace
Client: Windows 10 build 10500 or higher
Server: Windows Server 2016 Technical Preview build 10500 or higher
Phone: Windows 10 build 10500 or higher
- If you download the samples ZIP, be sure to unzip the entire archive, not just the folder with the sample you want to build.
- Start Microsoft Visual Studio 2017 and select File > Open > Project/Solution.
- Starting in the folder where you unzipped the samples, go to the Samples subfolder, then the subfolder for this specific sample, then the subfolder for your preferred language (C++, C#, or JavaScript). Double-click the Visual Studio Solution (.sln) file.
- Press Ctrl+Shift+B, or select Build > Build Solution.
The next steps depend on whether you just want to deploy the sample or you want to both deploy and run it.
- Select Build > Deploy Solution.
- To debug the sample and then run it, press F5 or select Debug > Start Debugging. To run the sample without debugging, press Ctrl+F5 or select Debug > Start Without Debugging.