[C# 문법] DataTable 데이터를 특정 Class에 값 넣어주기(FileInfo)
- C#/C# 문법
- 2020. 9. 18. 16:27
안녕하세요.
오늘은 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
'C# > C# 문법' 카테고리의 다른 글
[C# 문법] C# 처리하지 못한 예외 처리하는 방법 (0) | 2020.09.24 |
---|---|
[C# 문법] C# Linq를 이용하여 List와 List 비교하기 (0) | 2020.09.19 |
[C# 문법] C# Enum Count 가져오는 방법 (0) | 2020.09.15 |
[C# 문법] DataTable 특정 컬럼 값 더하기(Compute) (0) | 2020.09.14 |
[C# 문법] C# List 컬렉션 foreach 역으로 탐색하기 (0) | 2020.09.10 |
이 글을 공유하기