当前位置: 首页>>代码示例>>C#>>正文


C# FileInfo.Select方法代码示例

本文整理汇总了C#中System.IO.FileInfo.Select方法的典型用法代码示例。如果您正苦于以下问题:C# FileInfo.Select方法的具体用法?C# FileInfo.Select怎么用?C# FileInfo.Select使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在System.IO.FileInfo的用法示例。


在下文中一共展示了FileInfo.Select方法的10个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: GetFiles

 private static IEnumerable<ICompletionValue> GetFiles(FileInfo[] files)
 {
     return files
         .Select(x => x.Name.StartsWith("_") ? x.Name.Substring(1) : x.Name)
         .Select(x => new FileSystemCompletionValue(
             displayText: x,
             completionText: Path.GetFileNameWithoutExtension(x),
             closeValue: true
         ));
 }
开发者ID:profet23,项目名称:SassyStudio,代码行数:10,代码来源:ImportFileCompletionProvider.cs

示例2: CountWords

        /// <summary>
        /// Count occurrences of unique words in the given collection of files and write
        /// a list of words in descending order to the specified file.
        /// </summary>
        /// <param name="inputFiles">A collection of files to read.</param>
        /// <param name="outputFilePath">The file name for writing the results.</param>
        /// <param name="ignoreCase">Indicates whether letter casing should be ignored.</param>
        public void CountWords(FileInfo[] inputFiles, string outputFilePath, bool ignoreCase = true)
        {
            var index = new Dictionary<string, int>();
            var docs = new Dictionary<string, List<int>>();

            int doc = 0;

            var fileWordSeqs = inputFiles.Select(f => GetFileTokens(f.FullName, ignoreCase));

            foreach (var sequence in fileWordSeqs)
            {
                foreach (string word in sequence)
                {
                    int count;
                    index[word] = index.TryGetValue(word, out count) ? count + 1 : 1;

                    List<int> docList;
                    if (docs.TryGetValue(word, out docList))
                        docList.Add(doc);
                    else
                        docs[word] = new List<int> { doc };
                }

                doc++;
            }

            // Trim rare words
            var words = index.Keys.Where(word => docs.ContainsKey(word) && docs[word].Count < 3).ToList();
            foreach (string word in words)
            {
                index.Remove(word);
                docs.Remove(word);
            }

            var orderedWords = index.OrderByDescending(pair => pair.Value).Select(pair => pair.Key).ToList();
            var json = JsonConvert.SerializeObject(orderedWords, Formatting.Indented);
            File.WriteAllText(outputFilePath, json);
        }
开发者ID:McBits,项目名称:LanguageLib,代码行数:45,代码来源:WordCounter.cs

示例3: FindMatchingFiles

        private void FindMatchingFiles(DirectoryInfo dir, FileInfo[] files)
        {
            FileInfo[] tempfiles = this.Recursive ? dir.GetFiles(this.SearchPattern, SearchOption.AllDirectories) : dir.GetFiles(this.SearchPattern, SearchOption.TopDirectoryOnly);
            if (this.ModifiedAfterDate != Convert.ToDateTime("01/01/0001 00:00:00", CultureInfo.CurrentCulture) && this.ModifiedBeforeDate == Convert.ToDateTime("01/01/0001 00:00:00", CultureInfo.CurrentCulture))
            {
                files = (from f in tempfiles
                         where f.LastWriteTime > this.ModifiedAfterDate
                         select f).ToArray();
            }

            if (this.ModifiedBeforeDate != Convert.ToDateTime("01/01/0001 00:00:00", CultureInfo.CurrentCulture) && this.ModifiedAfterDate == Convert.ToDateTime("01/01/0001 00:00:00", CultureInfo.CurrentCulture))
            {
                files = (from f in tempfiles
                         where f.LastWriteTime < this.ModifiedBeforeDate
                         select f).ToArray();
            }

            if (this.ModifiedBeforeDate != Convert.ToDateTime("01/01/0001 00:00:00", CultureInfo.CurrentCulture) && this.ModifiedAfterDate != Convert.ToDateTime("01/01/0001 00:00:00", CultureInfo.CurrentCulture))
            {
                files = (from f in tempfiles
                         where f.LastWriteTime < this.ModifiedBeforeDate & f.LastWriteTime > this.ModifiedAfterDate
                         select f).ToArray();
            }

            if (this.ModifiedBeforeDate == Convert.ToDateTime("01/01/0001 00:00:00", CultureInfo.CurrentCulture) && this.ModifiedAfterDate == Convert.ToDateTime("01/01/0001 00:00:00", CultureInfo.CurrentCulture))
            {
                files = tempfiles;
            }

            this.items = files.Select(fileInfo => new TaskItem(fileInfo.FullName)).Cast<ITaskItem>().ToList();
        }
开发者ID:hamidshahid,项目名称:MSBuildExtensionPack,代码行数:31,代码来源:FindUnder.cs

示例4: CompileCSharp

		private static void CompileCSharp(FileInfo[] sources, IEnumerable<string> dependencyPaths, string assemblyPath, bool isApp)
		{
			Directory.CreateDirectory(Path.GetDirectoryName(assemblyPath));
			EmitResult result;
			var assemblyFileName = Path.GetFileNameWithoutExtension(assemblyPath);

			var syntaxTrees =
				sources.Select(src => CSharpSyntaxTree.ParseText(File.ReadAllText(src.FullName), null, src.FullName)).ToArray();
			var references = new List<PortableExecutableReference>()
			{
				MetadataReference.CreateFromFile(typeof(object).Assembly.Location),
				MetadataReference.CreateFromFile(typeof(DynamicAttribute).Assembly.Location),
			};
			references.AddRange(dependencyPaths.Select(p => MetadataReference.CreateFromFile(p)));
			using(var stream = File.Create(assemblyPath))
			{
				var compilation = CSharpCompilation.Create(assemblyFileName,
					syntaxTrees,
					references,
					new CSharpCompilationOptions(isApp ? OutputKind.ConsoleApplication : OutputKind.DynamicallyLinkedLibrary)
					);
				// Trick to make version show up in properties dialog
				using(var win32ResStream = compilation.CreateDefaultWin32Resources(versionResource: true, noManifest: false, manifestContents: null, iconInIcoFormat: null))
				{
					result = compilation.Emit(stream, win32Resources: win32ResStream);
				}
			}
			if(!result.Success)
			{
				File.Delete(assemblyPath);
				foreach(var group in result.Diagnostics.GroupBy(d => d.Location.SourceTree.FilePath))
				{
					Console.WriteLine($"In {group.Key}");
					foreach(var diagnostic in group)
					{
						Console.WriteLine(diagnostic);
					}
				}
				throw new BuildFailedException();
			}
			var binDir = Path.GetDirectoryName(assemblyPath);
			foreach(var reference in references.Skip(2))
				File.Copy(reference.FilePath, Path.Combine(binDir, Path.GetFileName(reference.FilePath)));
		}
开发者ID:adamant-deprecated,项目名称:AdamantBootstrapCompiler,代码行数:44,代码来源:Program.cs

示例5: ParallelZipFiles

		/// <summary>
		/// Zips a set of files (that must be rooted at the given RootDir) to a set of zip files in the given OutputDir. The files will be prefixed with the given basename.
		/// </summary>
		/// <param name="InputFiles">Fully qualified list of files to zip (must be rooted at RootDir).</param>
		/// <param name="RootDir">Root Directory where all files will be extracted.</param>
		/// <param name="OutputDir">Location to place the set of zip files created.</param>
		/// <param name="StagingDir">Location to create zip files before copying them to the OutputDir. If the OutputDir is on a remote file share, staging may be more efficient. Use null to avoid using a staging copy.</param>
		/// <param name="ZipBaseName">The basename of the set of zip files.</param>
		/// <returns>Some metrics about the zip process.</returns>
		/// <remarks>
		/// This function tries to zip the files in parallel as fast as it can. It makes no guarantees about how many zip files will be created or which files will be in which zip,
		/// but it does try to reasonably balance the file sizes.
		/// </remarks>
		private static FileInfo[] ParallelZipFiles(FileInfo[] InputFiles, DirectoryReference RootDir, DirectoryReference OutputDir, DirectoryReference StagingDir, string ZipBaseName)
		{
			// First get the sizes of all the files. We won't parallelize if there isn't enough data to keep the number of zips down.
			var FilesInfo = InputFiles
				.Select(InputFile => new { File = new FileReference(InputFile), FileSize = InputFile.Length })
				.ToList();

			// Profiling results show that we can zip 100MB quite fast and it is not worth parallelizing that case and creating a bunch of zips that are relatively small.
			const long MinFileSizeToZipInParallel = 1024 * 1024 * 100L;
			var bZipInParallel = FilesInfo.Sum(FileInfo => FileInfo.FileSize) >= MinFileSizeToZipInParallel;

			// order the files in descending order so our threads pick up the biggest ones first.
			// We want to end with the smaller files to more effectively fill in the gaps
			var FilesToZip = new ConcurrentQueue<FileReference>(FilesInfo.OrderByDescending(FileInfo => FileInfo.FileSize).Select(FileInfo => FileInfo.File));

			// We deliberately avoid Parallel.ForEach here because profiles have shown that dynamic partitioning creates
			// too many zip files, and they can be of too varying size, creating uneven work when unzipping later,
			// as ZipFile cannot unzip files in parallel from a single archive.
			// We can safely assume the build system will not be doing more important things at the same time, so we simply use all our logical cores,
			// which has shown to be optimal via profiling, and limits the number of resulting zip files to the number of logical cores.
			// 
			// Sadly, mono implementation of System.IO.Compression is really poor (as of 2015/Aug), causing OOM when parallel zipping a large set of files.
			// However, Ionic is MUCH slower than .NET's native implementation (2x+ slower in our build farm), so we stick to the faster solution on PC.
			// The code duplication in the threadprocs is unfortunate here, and hopefully we can settle on .NET's implementation on both platforms eventually.
			List<Thread> ZipThreads;

			ConcurrentBag<FileInfo> ZipFiles = new ConcurrentBag<FileInfo>();

			DirectoryReference ZipDir = StagingDir ?? OutputDir;
			if (Utils.IsRunningOnMono)
			{
				ZipThreads = (
					from CoreNum in Enumerable.Range(0, bZipInParallel ? Environment.ProcessorCount : 1)
					let ZipFileName = FileReference.Combine(ZipDir, string.Format("{0}{1}.zip", ZipBaseName, bZipInParallel ? "-" + CoreNum.ToString("00") : ""))
					select new Thread(() =>
					{
						// don't create the zip unless we have at least one file to add
						FileReference File;
						if (FilesToZip.TryDequeue(out File))
						{
							// Create one zip per thread using the given basename
							using (var ZipArchive = new Ionic.Zip.ZipFile(ZipFileName.FullName) { CompressionLevel = Ionic.Zlib.CompressionLevel.BestSpeed })
							{

								// pull from the queue until we are out of files.
								do
								{
									// use fastest compression. In our best case we are CPU bound, so this is a good tradeoff,
									// cutting overall time by 2/3 while only modestly increasing the compression ratio (22.7% -> 23.8% for RootEditor PDBs).
									// This is in cases of a super hot cache, so the operation was largely CPU bound.
									ZipArchive.AddFile(File.FullName, CommandUtils.ConvertSeparators(PathSeparator.Slash, File.Directory.MakeRelativeTo(RootDir)));
								} while (FilesToZip.TryDequeue(out File));
								ZipArchive.Save();
							}
							// if we are using a staging dir, copy to the final location and delete the staged copy.
							FileInfo ZipFile = new FileInfo(ZipFileName.FullName);
							if (StagingDir != null)
							{
								FileInfo NewZipFile = ZipFile.CopyTo(CommandUtils.MakeRerootedFilePath(ZipFile.FullName, StagingDir.FullName, OutputDir.FullName));
								ZipFile.Delete();
								ZipFile = NewZipFile;
							}
							ZipFiles.Add(ZipFile);
						}
					})).ToList();
			}
			else
			{
				ZipThreads = (
					from CoreNum in Enumerable.Range(0, bZipInParallel ? Environment.ProcessorCount : 1)
					let ZipFileName = FileReference.Combine(ZipDir, string.Format("{0}{1}.zip", ZipBaseName, bZipInParallel ? "-" + CoreNum.ToString("00") : ""))
					select new Thread(() =>
					{
						// don't create the zip unless we have at least one file to add
						FileReference File;
						if (FilesToZip.TryDequeue(out File))
						{
							// Create one zip per thread using the given basename
							using (var ZipArchive = System.IO.Compression.ZipFile.Open(ZipFileName.FullName, System.IO.Compression.ZipArchiveMode.Create))
							{

								// pull from the queue until we are out of files.
								do
								{
									// use fastest compression. In our best case we are CPU bound, so this is a good tradeoff,
									// cutting overall time by 2/3 while only modestly increasing the compression ratio (22.7% -> 23.8% for RootEditor PDBs).
									// This is in cases of a super hot cache, so the operation was largely CPU bound.
//.........这里部分代码省略.........
开发者ID:zhaoyizheng0930,项目名称:UnrealEngine,代码行数:101,代码来源:TempStorage.cs

示例6: TempStorageManifest

		/// <summary>
		/// Creates a manifest from a flat list of files (in many folders) and a BaseFolder from which they are rooted.
		/// </summary>
		/// <param name="InFiles">List of full file paths</param>
		/// <param name="RootDir">Root folder for all the files. All files must be relative to this RootDir.</param>
		public TempStorageManifest(FileInfo[] InFiles, DirectoryReference RootDir)
		{
			Files = InFiles.Select(x => new TempStorageFile(x, RootDir)).ToArray();
		}
开发者ID:zhaoyizheng0930,项目名称:UnrealEngine,代码行数:9,代码来源:TempStorage.cs

示例7: ResolveJavaArchiveLoadRequest

		public static string ResolveJavaArchiveLoadRequest(string context, string name, FileInfo[] ImplicitReferences)
		{
			Func<string[], string> f =
				list =>
				{
					var r = name.Replace(".", "/") + ".class";

					foreach (var item in list)
					{
						var c = default(string[]);

						if (!FileContentLookup.ContainsKey(item))
						{
							// https://sites.google.com/a/jsc-solutions.net/backlog/knowledge-base/2014/201402/20140209

							Console.WriteLine("JavaArchiveExtensions.ResolveJavaArchiveLoadRequest " +
								new
								{
									jar = Path.GetFileNameWithoutExtension(item),
									context,
									name
								}
							);

							var zip = ZIPArchive.GetFiles(item);

							FileContentLookup[item] = zip.Select(k => k.Name).ToArray();
						}

						c = FileContentLookup[item];

						var u = c.FirstOrDefault(k => k == r);

						if (u != null)
							return item;
					}

					return null;
				};

			var x0 = f(ImplicitReferences.Select(k => k.FullName).ToArray());

			if (x0 != null)
				return x0;

			Console.WriteLine("JavaArchiveExtensions.ResolveJavaArchiveLoadRequest " +
				new
				{
					context,
					name
				}
			);

			var x1 = f(ContextToFileArray(context));



			//MessageBox.Show("@ JavaArchiveResolve: " + name);

			//if (name == "com.amazonaws.AmazonWebServiceRequest")
			//    return @"C:\util\aws-android-sdk-0.2.0\lib\aws-android-sdk-0.2.0-core.jar";

			return x1;
		}
开发者ID:exaphaser,项目名称:JSC-Cross-Compiler,代码行数:64,代码来源:JavaArchiveExtensions.cs

示例8: DetectTypeOfCurves

 /// <summary>
 /// Определяет тип кривых файлы которых находятся в указанной папке
 /// </summary>
 /// <param name="fiList"></param>
 /// <returns></returns>
 private string DetectTypeOfCurves(FileInfo[] fiList)
 {
     string[] types = {".txt", ".s1p", ".s2p", ".s3p", ".s4p"};
     string res = fiList.Select(fi => Path.GetExtension(fi.FullName.ToLower())).FirstOrDefault(ext => types.Contains(ext));
     return res ?? "";
 }
开发者ID:NIIPP-Repository,项目名称:SCYSET,代码行数:11,代码来源:NIIPP.WaferMeasData.cs

示例9: ReadHashFiles

        private static HashFile[] ReadHashFiles(FileInfo[] files, long maxSize)
        {
            Console.Write("Reading Hashfiles");
            var hashFiles = files
                .Select(f => HashFile.Create(f))
                .Where(h => h != null && h.SourceFile != null && h.SourceFile.Exists && (maxSize == -1 || h.SourceFile.Length <= maxSize))
                .ToArray();

            var filtered =
            (
                from file in hashFiles
                join hash in hashdata.Values
                    on file.SourceName.ToLower()
                    equals hash.Path.ToLower()
                    into hashlist
                from h in hashlist.DefaultIfEmpty()
                where
                    h == null ||
                    // h.Updated.AddMinutes(20) < DateTime.Now ||
                    (file.SourceFile.Length != h.FileLength || file.SourceFile.LastWriteTime != h.LastWriteTime)
                select file
            ).ToArray();

            Console.WriteLine(" - Loaded {0} of {2} Hashfile{1}", filtered.Length, hashFiles.Length == 1 ? "" : "s", hashFiles.Length);

            return filtered.Length < 1 ? null : filtered;
        }
开发者ID:Corey-M,项目名称:Misc,代码行数:27,代码来源:Program.cs

示例10: ImageFolder

 public ImageFolder(
     DirectoryInfo thisDir, DirectoryInfo rootDir, FileInfo[] imageFiles)
 {
     this.thisDir = thisDir;
     this.rootDir = rootDir;
     this.files = imageFiles.Select(x => new ImageFile(x)).ToArray();
 }
开发者ID:gdtiti,项目名称:qq-game-resource,代码行数:7,代码来源:ResourceViewModel.cs


注:本文中的System.IO.FileInfo.Select方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。