C#员工工资文件处理

对员工工资文件处理,所有人的工资+100然后输出到新文件。具体要求:
1、首先从sal文件中,把内容一行行的读出来。
2、然后用splt()函数,来处理读出来的字符串,把姓名和工资分开
3、接着把工资加100
4、最后再把加过工资的信息存入新文件salnew.txt中
例如:加分前,sal文件中存放的数据形式如下:
E
张三:2000
王二:3000
李四:4000
答题详情
加分后,在新文件scorenew.txt文件中内容为:
张三:2100
王二:3100
李四:4100

题主要的代码如下

img

using System;
using System.IO;
using System.Text;
namespace ConsoleApp1
{
    class Program
    {
        static void Main(string[] args)
        {            
            var arr = File.ReadAllLines("sal.txt", Encoding.UTF8);//注意sal.txt文件编码,如果不是utf8,为ansi改为Encoding.GetEncoding(936),要不会乱码
            for(var i = 0; i < arr.Length; i++)
            {
                var item = arr[i].Split(':');
                arr[i] = item[0] + ':' + (int.Parse(item[1]) + 100);
            }
            File.WriteAllLines("salnew.txt", arr, Encoding.UTF8);
            Console.WriteLine("操作成功");
            Console.ReadKey();
        }
    }
}

有帮助麻烦点下【采纳该答案】,谢谢~~有其他问题可以继续交流~

如果这是实际问题,你可以看我的回答
如果这是一个习题或者一个面试题,请忽略我的回答,因为我这个回答,不是他们想要的。

作为实际问题,我们当作Data frame问题。所以我们选择一些本身具备data frame处理的工具(如果是面试题---他可不愿意看到你这么偷懒的解决问题,这不是他想考的东西)
1.nuget Deedle
编写如下代码:

  var fb = Frame.ReadCsv("salnew.txt", hasHeaders: false, separators: ":",schema:"name,sal");
            var scorenew = fb.ColumnApply((Series<int, int> numeric) =>
                numeric.Select(kvp => kvp.Value+100));
            scorenew.SaveCsv("scorenew.txt",separator:':',includeRowKeys:false);