两个文本文件之间的映射包含阿拉伯字符c#

时间:2013-09-18 19:20:01

标签: c#

我的文本文件包含如下数据:

ID 1 Name Mary Mark 89
ID 2 Name Mai   Mark 67

我有另一个包含数据的文本文件:

ID  Mobile
1   0993209320
2   0943043094

我想创建只包含两列的excel文件:

Mobile                      Message
0993209320            ID 1 Name Mary Mark 89
0943043094            ID 2 Name Mai   Mark 67

要做到这一点,我尝试了下面的代码,它运行正常,并且创建了所需的excel文件,但是当我将两个文本文件中包含的数据更改为阿拉伯语时,代码创建了excel文件,但是空,应该是什么我修改代码使其能够处理阿拉伯字符??
这是代码:

    DataTable dtMapping = new DataTable();
    ArrayList lstMapping = new ArrayList();
    dtMapping.Columns.Add("Mobile"); dtMapping.Columns.Add("Message");
    string[] readFile1 = File.ReadAllLines(Location of 1st file);
    string[] readFile2 = File.ReadAllLines(Location of 2nd file);


         for (int i = 0; i < readFile1.Length; i++)
            {
                string fileData = readFile1[i].ToString();
                int find_Id_Index = fileData.IndexOf("ID ");
                if (find_Id_Index != -1)
                {
                    int find_Name_Index = fileData.IndexOf("Name ", find_Id_Index);
                   string id = fileData.Substring(find_Id_Index+3,find_Name_Index-(find_Id_Index+3) ).Trim();
                    lstMapping.Add("ID " + id);
                    lstMapping.Add(fileData.Substring(find_Name_Index, fileData.Length - (find_Name_Index)).Trim());
                }
            }


            for (int i = 1; i < readFile2.Length; i++)
            {
                int find_Space_Index = readFile2[i].IndexOf(" ");
                if (find_Space_Index != -1)
                {
                    string file2id = readFile2[i].Substring(0, find_Space_Index).Trim();
                    string mobileno = readFile2[i].Substring(find_Space_Index, readFile2[2].Length - (find_Space_Index - file2id.Length+1)).Trim();
                    int find_Id = lstMapping.IndexOf("ID " + file2id);
                    if (find_Id != -1)
                    {
                        dtMapping.Rows.Add(mobileno, "ID " + file2id + " " + lstMapping[find_Id + 1]);
                    }
                }
            }


            Microsoft.Office.Interop.Excel.Application excelApp = new Microsoft.Office.Interop.Excel.Application();
            Microsoft.Office.Interop.Excel.Workbook workbook = excelApp.Workbooks.Add(Microsoft.Office.Interop.Excel.XlWBATemplate.xlWBATWorksheet);
            Microsoft.Office.Interop.Excel.Worksheet workSheet = (Microsoft.Office.Interop.Excel.Worksheet)workbook.Sheets[1];
            for (int i = 0; i < dtMapping.Columns.Count; i++)
            {
                workSheet.Cells[1, (i + 1)] = dtMapping.Columns[i].ColumnName;
            }
            for (int i = 0; i < dtMapping.Rows.Count; i++)
            {
                for (int j = 0; j < dtMapping.Columns.Count; j++)
                {
                    workSheet.Cells[(i + 2), (j + 1)] = dtMapping.Rows[i][j];
                }
            }
            excelApp.Visible = true;

0 个答案:

没有答案