[C# 문법] DataTable 데이터를 특정 Class에 값 넣어주기(FileInfo)

안녕하세요.

 

오늘은 C# 문법에서 DataTable 에 저장되어 있는 테이블의 각 컬럼 정보 및 데이터를 특정 Class 객체에 알맞게 넣어주는 방법에 대해서 알려 드리려고 합니다.

 

제가 예제 프로그램으로 작성한 내용은 아래와 같습니다.

 

시나리오

1.   Student DataTable 하나 생성

2.   DataTable 안에 컬럼 및 데이터 저장

3.   Student Class 생성

4.   DataTable안의 데이터를 Student 클래스 객체에 저장

5.   Student 클래스 정보를 저장할 리스트 생성 및 저장

6.   List 값 출력

 

위에 정의한 시나리오 대로 예제 프로그램을 만들어 보도록 하겠습니다.

 

예제 코드
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
using System;
using System.Collections.Generic;
using System.Data;
using System.Linq;
using System.Reflection;
using System.Text;
using System.Threading.Tasks;
 
namespace TestProgram
{
    class Program
    {
        static List<Student> _stuList = new List<Student>();
 
        static void Main(string[] args)
        {
            //데이터 테이블 생성
            SetList(CreateDataTable());
 
            foreach (var item in _stuList)
            {
                Console.WriteLine($"이름 : {item.NAME} 나이 : {item.AGE} 성적 : {item.SCORE}");
            }
        }
 
        /// <summary>
        /// 테스트 DataTable 생성
        /// </summary>
        /// <returns></returns>
        public static DataTable CreateDataTable()
        {
            DataTable dt = new DataTable();
 
            //컬럼 생성
            CreateColumn(dt);
 
            //Row 데이터 추가
            AddRow(dt);
 
            return dt;
        }
 
        /// <summary>
        /// 컬럼 생성
        /// </summary>
        /// <param name="dt"></param>
        public static void CreateColumn(DataTable dt)
        {
            dt.Columns.Add("NAME"typeof(string));
            dt.Columns.Add("AGE"typeof(string));
            dt.Columns.Add("SCORE"typeof(int));
        }
 
        /// <summary>
        /// Row 추가
        /// </summary>
        /// <param name="dt"></param>
        public static void AddRow(DataTable dt)
        {
            dt.Rows.Add("범범조조""28"100);
            dt.Rows.Add("아이유""21"10);
            dt.Rows.Add("유재석""48"98);
            dt.Rows.Add("아이린""48"73);
            dt.Rows.Add("백현""24"54);
        }
        public static void SetList(DataTable dt)
        {
            for (int i = 0; i < dt.Rows.Count; i++)
            {
                Student st = new Student();
                ParserToOBJ(st, dt, i);
                _stuList.Add(st);
            }
        }
 
        public static void ParserToOBJ(object obj, DataTable dt, int targetRowNum)
        {
            FieldInfo[] infoArr = obj.GetType().GetFields();
            string colName = string.Empty;
            string value = string.Empty;
 
            for (int i = 0; i < infoArr.Length; i++)
            {
                for (int col = 0; col < dt.Columns.Count; col++)
                {
                    colName = dt.Columns[col].ColumnName.ToUpper();
 
                    if (infoArr[i].Name == colName && (infoArr[i].FieldType.Name == "String"))
                    {
                        value = dt.Rows[targetRowNum][col].ToString();
                        FieldInfo info = infoArr[i];
                        info.SetValue(obj, value);
                        break;
                    }
 
                    if (infoArr[i].Name == colName && (infoArr[i].FieldType.Name == "Int32"))
                    {
                        value = dt.Rows[targetRowNum][col].ToString();
                        FieldInfo info = infoArr[i];
                        info.SetValue(obj,Convert.ToInt32(value));
                        break;
                    }
                }
            }
 
        }
 
    }
 
    public class Student
    {
        public string NAME = string.Empty;
        public string AGE = string.Empty;
        public int SCORE = 0;
    }
}
 
cs

 

실행 결과

보시는 것과 같이, DataTable의 값이 Student 클래스 객체에 알맞게 저장되고, 최종적으로 _stuList를 출력하니까 DataTalbe에 저장되어 있던 값들이 제대로 Student 클래스 객체에 저장되어 출력되는 것을 확인하실 수 있습니다.

 

감사합니다.^^

728x90

이 글을 공유하기

댓글

Designed by JB FACTORY