Files
Unimarc/unimarc/unimarc/마크/Mac_Input.cs
SeungHo Yang 47eb194df7 DB 구조 변경
쿼리를 먼저 만들어 DB로 보내게 됨.
함수 분할함.
2021-09-13 10:58:18 +09:00

161 lines
5.7 KiB
C#
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.IO;
using System.Linq;
using System.Text;
using System.Text.RegularExpressions;
using System.Threading.Tasks;
using System.Windows.Forms;
namespace WindowsFormsApp1.Mac
{
public partial class Mac_Input : Form
{
Helper_DB db = new Helper_DB();
Main main;
public Mac_Input(Main _main)
{
InitializeComponent();
main = _main;
}
private void Mac_Input_Load(object sender, EventArgs e)
{
db.DBcon();
string[] com_list = { "표준Marc", "라인Marc" };
comboBox1.Items.AddRange(com_list);
comboBox1.SelectedIndex = 0;
}
private void btn_FileOpen_Click(object sender, EventArgs e)
{
string file_path = string.Empty;
if (tb_filePath.Text != "")
{
openFileDialog1.InitialDirectory = tb_filePath.Text;
}
if (openFileDialog1.ShowDialog() == DialogResult.OK)
{
file_path = openFileDialog1.FileName;
dataGridView1.Rows.Clear();
try
{
StreamReader r = new StreamReader(file_path, Encoding.Default);
input_Grid(r.ReadToEnd());
r.Close();
}
catch(Exception ex)
{
// 
MessageBox.Show(ex.ToString());
}
}
tb_filePath.Text = file_path;
}
void input_Grid(string text)
{
string[] grid = text.Split('');
for (int a = 0; a < grid.Length - 1; a++)
{
if (comboBox1.SelectedIndex != 0)
grid[a] = grid[a].Replace("\r\n", "");
string[] data = Split_Marc(grid[a]);
data[0] = data[0].Replace(":", "");
data[6] = grid[a] + "";
dataGridView1.Rows.Add(data);
}
}
string[] Split_Marc(string text)
{
string tmp_string = text.Remove(0, 24);
string[] Marc = tmp_string.Split('');
string[] dir = made_Directory(Marc[0]);
string[] data = { "", "", "", "", "", "", "" }; // isbn, 도서명, 총서명, 저자, 출판사, 정가, marc
String_Text st = new String_Text();
for(int a = 0; a < dir.Length; a++)
{
if (dir[a] == "020")
{
data[0] = st.GetMiddelString(Marc[a + 1], "a", ""); // isbn
data[5] = st.GetMiddelString(Marc[a + 1], "c", ""); // 정가
}
if (dir[a] == "245")
{
data[1] = st.GetMiddelString(Marc[a + 1], "a", ""); // 도서명
data[3] = st.GetMiddelString(Marc[a + 1], "d", ""); // 저자
}
if (dir[a] == "260")
{
data[4] = st.GetMiddelString(Marc[a + 1], "b", ""); // 출판사
}
if (dir[a] == "440")
{
data[2] = st.GetMiddelString(Marc[a + 1], "a", ""); // 총서명
}
if (dir[a] == "950")
{
data[5] = st.GetMiddelString(Marc[a + 1], "b", ""); // 정가
}
}
return data;
}
string[] made_Directory(string value)
{
int length = value.Length;
int start = 0;
List<string> L_dir = new List<string>();
while (true)
{
if (start + 12 > length) { break; }
L_dir.Add(value.Substring(start, 3));
start += 12;
}
string[] result = L_dir.ToArray();
return result;
}
private void dataGridView1_RowPostPaint(object sender, DataGridViewRowPostPaintEventArgs e)
{
Skill_Grid sg = new Skill_Grid();
sg.Print_Grid_Num(sender, e);
}
private void btn_db_save_Click(object sender, EventArgs e)
{
string table = "Marc";
string[] col = { "grade", "ISBN", "서명", "총서명", "저자", "출판사", "가격", "marc", "marc_chk" };
for(int a = 0; a < dataGridView1.Rows.Count; a++)
{
string Marc = dataGridView1.Rows[a].Cells["Marc"].Value.ToString();
Marc = Marc.Replace(@"'", "'");
Marc = Marc.Replace(@"""", "\"\"");
string[] data = { "2", dataGridView1.Rows[a].Cells["isbn"].Value.ToString(),
dataGridView1.Rows[a].Cells["book_name"].Value.ToString(),
dataGridView1.Rows[a].Cells["series"].Value.ToString(),
dataGridView1.Rows[a].Cells["author"].Value.ToString(),
dataGridView1.Rows[a].Cells["book_comp"].Value.ToString(),
dataGridView1.Rows[a].Cells["price"].Value.ToString(),
Marc, "1" };
string Incmd = db.DB_INSERT(table, col, data);
db.DB_Send_CMD_reVoid(Incmd);
}
MessageBox.Show("DB 저장 완료!");
}
private void btn_close_Click(object sender, EventArgs e)
{
Close();
}
private void dataGridView1_KeyUp(object sender, KeyEventArgs e)
{
Skill_Grid sg = new Skill_Grid();
sg.clipboard_not_crack(sender, e);
}
}
}