如何拆分文本文件并使用整数?

时间:2017-08-01 17:24:14

标签: c#

我有一个显示学生姓名及其分数的文本文件。格式如下:

James Johnson, 85
Robert Jones, 90
Lindsey Parks, 98
etc.

我有10个名字和得分都是以上格式。我的问题是如何通过分隔符拆分文本文件,并使用文本文件中的整数

到目前为止,这是我的代码:

using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.IO;
using Microsoft.VisualBasic;
using Microsoft.VisualBasic.FileIO;
namespace TextFiles1
{
  class Program    
  {        
    static void Main(string[] args)        
    {
      StreamReader sr = new StreamReader(@"C:\Users\jonda\Desktop\StudentScores.txt.txt");            
      string data = sr.ReadLine();            
      while (data != null)            
      {                
        Console.WriteLine(data);                
        string[] names = data.Split(',');                
        data = sr.ReadLine();            
      }            
      int total = 0;            
      double average = 0;            
      for (int index = 0; index < data.Length; index++)  
      {   
        total = total + data[index];
      }            
      average = (double)total / data.Length;            
      Console.WriteLine("Average = " + average.ToString("N2"));            
      int high = data[0];            
      for (int index = 0; index < data.Length; index++)                
      {                     
        if (data[index] > high)                     
        {                         
          high = data[index];                     
        }
      }            

      Console.WriteLine("Highest Score =" + high);           
      sr.Close();
      Console.ReadLine();
    }
  }
}

2 个答案:

答案 0 :(得分:3)

首先,将文件操作和其他操作分开是一个好主意。文件操作缓慢且成本高昂,应尽快完成。我会使用一个单独的方法,将行读入List并首先关闭文件操作。

    private static List<string> ReadFile(string path)
    {
        List<string> records = new List<string>();
        using (StreamReader sr = new StreamReader(path))
        {
            while (!sr.EndOfStream)
                records.Add(sr.ReadLine());
        }
        return records;
    }

然后我将该列表传递给另一个函数并计算平均值,最大值等。

private static void CalculateAverage(List<string> lines)
{
    char[] seperator = new char[] { ',' };
    List<int> scores = new List<int>();
    if (lines != null && lines.Count > 0)
    {
        foreach (string line in lines)
        {
            Console.WriteLine(line);
            string[] parts = line.Split(seperator);
            int val;
            if (int.TryParse(parts[1], out val))
                scores.Add(val);
        }
    }
    Console.WriteLine("Average: {0}", scores.Average());
    Console.WriteLine("Highest Score: {0}", scores.Max());
}

然后在你的主程序中调用这样的方法:

List<string> lines = ReadFile(path);
CalculateAverage(lines);

答案 1 :(得分:1)

使用Regex查找每个人信息,然后将每个信息拆分并提取NameScore

试试这样:

        var inputStr = "James Johnson, 85 Robert Jones, 90 Lindsey Parks, 98";
        var regex = new Regex(@"[A-z]* [A-z]*, [0-9]*");
        return  regex.Matches(inputStr)
            .OfType<Match>()
           .Select(p => p.Value.Split(','))
           .Select(p => new { Name = p[0], Score = Convert.ToInt32(p[1].Trim()) });

结果: The result

我希望对你有所帮助:)。