본문 바로가기

전체 글154

VB.NET에서 System.Reflection을 이용한 동적 DLL 사용하기: 예제와 설명 VB.NET에서 동적 DLL을 사용하는 방법은 매우 유용합니다. 동적 DLL은 프로그램 실행 중에 로드되어 사용되며, 라이브러리의 업데이트나 유지 관리를 용이하게 합니다. 아래 예제를 통해 VB.NET에서 동적 DLL을 사용하는 방법을 자세히 살펴보겠습니다. Imports System.Runtime.InteropServices Module MainModule ' DLL 함수의 프로토타입 정의 DllImport("example.dll", CallingConvention:=CallingConvention.Cdecl)> Public Function Add(ByVal a As Integer, ByVal b As Integer) As Integer End Function  Sub.. 2024. 4. 25.
VB.NET 마스터하기: 효율적인 Extension 메서드 사용법 VB.NET에서의 Extension 메서드는 기존 타입에 새로운 메서드를 추가하고자 할 때 유용하게 사용할 수 있는 기능입니다. 이를 통해 기존의 클래스, 구조체, 인터페이스 등에 새로운 기능을 추가할 수 있으며, 원본 소스 코드를 변경하지 않고도 기능을 확장할 수 있습니다. Extension 메서드 정의하는 방법 VB.NET에서 Extension 메서드를 정의하려면 다음과 같은 절차를 따릅니다: 모듈 선언: Extension 메서드는 모듈 내에 정의되어야 합니다. 모듈은 일반적으로 Module 키워드를 사용하여 선언합니다. 속성 사용: 메서드 앞에 속성을 명시하여 이 메서드가 Extension 메서드임을 나타냅니다. 첫 번째 파라미터는 ByVal 이어야 하며, 확장하고자 하는 타입을 정의합니다: 이 파.. 2024. 4. 17.
[VB.NET] 파일 저장 시 유효하지 않은 파일명에 대한 특수 문자 처리 및 복구 방법 Public Function StringToFileName(fName As String) As String Dim V() As String = {"%", "\", "/", ":", "*", "?", """", "", "|"} '// 변환시 Dim str As String = fName For Each T As String In V Dim s As String = CStr(Asc(T)) If s.Length 2024. 4. 17.
정규식(정규 표현식, Regular Expression) 정규식(정규 표현식, Regular Expression)은 텍스트에서 특정 패턴을 찾기 위해 사용하는 문자열입니다. 컴퓨터 과학에서 널리 사용되는 이 툴은 복잡한 검색과 문자열 치환 작업을 간편하게 수행할 수 있게 해줍니다. 여러 프로그래밍 언어 및 텍스트 편집 도구에서 지원합니다. 정규식의 기본 구성 요소 리터럴(Literals): 텍스트 그대로의 문자입니다. 예를 들어, 정규식 abc는 "abc"라는 문자열과 일치합니다. 메타 문자(Meta Characters): 특별한 의미를 가진 문자로, 패턴을 구성하는 데 사용됩니다. 자주 사용되는 메타 문자에는 다음이 포함됩니다. .: 어떤 한 문자와 일치 (개행 문자 제외) ^: 입력의 시작과 일치 $: 입력의 끝과 일치 *: 앞의 요소가 0회 이상 반복 +.. 2024. 4. 17.
정말 야한 이미지... 위에 이미지 다운받아서 저에게 보내 주세요 ^^ 저한테 야~ 이러실 겁니다. 그래서 "정말 야한 이미지" 입니다. ㅋㅋㅋ 2024. 4. 17.
웃음(laugh)의 힘!! 정서적, 사회적, 건강적 이점 사람들은 어릴 때 웃습니다. 하지만 자라면서 웃지 않습니다. People laugh when they are young. But as the grow up, they don't laugh. 6살짜리 아이는 하루에 300번 웃는 반면 어른은 하루에 17번만 웃습니다 A six-year-old child laughs 300 times a day whereas an adult only laughs 17 times a day 우리는 행복해서 웃는 것이 아니라, 웃기 때문에 행복합니다. We don't laugh because we're happy, we're happy because we laugh. 웃음은 인간 표현의 가장 기본적인 형태 중 하나이며 감정 공유, 사회적 결속력 강화, 스트레스 해소 등 다양한 .. 2024. 4. 17.
DMX-512 Dimming UNIT 수개월의 작업끝에 결실을 맺었습니다. 89C51와 ATMega8을 이용한 메인보드를 테스트까지 완성!! 제로크로싱 회로의 여러번 실패로 낙심하다 구글신을 영접후 열이 제로에 가깝게 구현되었고 회로도 아주 간소화 되었습니다. 대표사진 삭제 사진 설명을 입력하세요. 아래가 제로크로싱 회로입니다. 많은 사연이 있는 놈이지요 ^^ 대표사진 삭제 사진 설명을 입력하세요. 8M의 내부 크리스탈을 이용 타이머로 동기 신호부입니다. 대표사진 삭제 사진 설명을 입력하세요. eep rom에서 어드레스를 자주 까먹어서 한동안 고생하고... 제로크로싱 회로 열로 해결법을 찿냐고 수일... 같이 함께해준 동생들과 형님 감사합니다. ^^ 올 한해는 대박나길 기대할께요.. 일년동안 고생 많았어요 ^^ 이제 전 저의 일상으로 Go~.. 2024. 4. 17.
♣ '명심보감' 에서 배우는 8가지 지혜 ♣ '명심보감' 에서 배우는 8가지 지혜 1. 남을 무시하지 말라. 태공이 말하였다. " 자기가 잘났다고 생각하여 남을 업신여겨서는 안 되고, 자기가 크다고 생각해서 작은 사람을 무시해서는 안되고, 용기를 믿고 적을 가볍게 대해서는 안된다. " 2. 힘으로 남을 이기려 하지 말라. 맹자가 말하였다. " 힘으로 남을 이기려 하면 겉으로는 복종하는 체하지만 진심으로 복종한 것이 아니라 힘이 부족해서요, 덕으로써 남을 복종시키려 하면 마음속으로 기뻐서 진심으로 복종하게 된다. " 3. 남을 해치고자 하면 자신이 먼저 당한다. 태공이 말하였다. " 남을 판단하고자 하면 먼저 자기부터 헤아려 봐라. 남을 해치는 말은 도리어 자신을 해치게 되니, 피를 머금었다가 남에게 뿜으면 먼저 자신의 입부터 더러워진다. " 4.. 2024. 4. 17.
N사 카페 투데이 프로그램 네이버 카페는 현대 사회에서 많은 이용자들이 즐겨 참여하는 소셜 미디어 플랫폼 중 하나입니다. 사용자는 카페에서 자신의 관심사와 주제에 대해 이야기하고 정보를 공유합니다. 이를 통해 다양한 그룹이 모여 소통하고 활발한 활동을 합니다. 네이버 카페 투데이 작업 프로그램은 이러한 카페 활동을 보다 효율적으로 운영할 수 있도록 도와주는 도구입니다. 이 프로그램은 쉽고 직관적인 기능을 제공하여 사용자가 투데이 작업을 보다 편리하게 수행할 수 있도록 도와줍니다. 우선 이 프로그램은 두 가지 주요 기능을 제공합니다. 첫째, 작업하고자 하는 횟수만큼 지정하여 투데이를 올릴 수 있습니다. 둘째, 프로그램은 지정한 투데이가 될 때까지 방문하는 기능입니다. 이러한 기능을 통해 네이버 카페 투데이 작업 프로그램은 사용자가 .. 2024. 3. 28.
프로젝트의 핵심, 맨먼스(M/M): 개발자의 노동시간을 어떻게 측정할까? 소프트웨어 개발이나 웹제작 등을 할 때 맨먼스라는 말을 들어보신 적 있으신가요? ​ 프로젝트를 기획하고 추진할 때, 핵심적인 고려 사항 중 하나는 바로 맨먼스(Man/Month)입니다. 이 용어는 한 사람이 한 달 동안 작업하면 끝낼 수 있는 양을 나타내는 개념으로, 프로젝트에 필요한 총 노동시간을 측정하는 중요한 도구로 사용됩니다. ​ 맨먼스는 시간의 흐름에 따라 다양한 단위로 표현됩니다. Man-Hour(1시간의 노동시간), Man-Day(1일 노동시간), Man-Week(1주일 노동시간), 그리고 Man-Month(1달 노동시간)이 그 주요한 단위입니다. 이를 통해 프로젝트의 작업 양과 필요한 노동시간을 명확하게 계획할 수 있습니다. ​ 예를 들어, 만약 한 사람이 10달 동안 일을 해야 한다면, .. 2023. 11. 22.
[vb.net] Ctrl + C, Ctrl + V 사용하기 PreviewKeyDown 이벤트를 활용해서 아주 간단하게 텍스트 박스에서 Ctrl + c, Ctrl + v, Ctrl + a, Ctrl + z ... 등 단축키가 가능하게 설정할 수 있습니다. Private Sub TextBox1_PreviewKeyDown(sender As Object, e As PreviewKeyDownEventArgs) Handles TextBox1.PreviewKeyDown If e.Control Then e.IsInputKey = True End Sub 내 프로젝트에서 모든 텍스트 박스에 적용하고자 한다면 사용자 정의 컨트롤을 만들어 사용하면 됩니다. Public Class TextBox Inherits Windows.Forms.TextBox Private Overloads S.. 2023. 11. 22.
[vb.net] LINQ(Language-Integrated Query)를 이용한 전자회로 저항갑 병렬, 직렬 계산하는 방법 LINQ란? LINQ(Language-Integrated Query)는 Visual Basic에 쿼리 기능을 추가하고 모든 종류의 데이터를 사용할 때 간단하고 강력한 기능을 제공합니다. LINQ는 처리할 데이터베이스에 쿼리를 보내거나 검색하는 각 데이터 형식에 대해 서로 다른 쿼리 구문을 사용하는 대신 Visual Basic 언어의 일부로 쿼리를 도입합니다. LINQ는 데이터의 형식에 관계없이 통합된 구문을 사용합니다. ​ 이쯤 간단히 MS 자료를 인용해 보고요 본격적으로 설명에 들어갑니다. ​ ​ ​ 1. 직렬연결일 경우 더한 값이 나온다 ​ 2. 병렬연결일 경우 하나라도 입력되지 않으면 계산이 안되므로 0으로 나온다. ​ 이와 같이 폼을 만들고 textBox1 ~ textBox4 는 저항값 입력입니다.. 2023. 11. 20.
PHP4를 지원하는 phpmyadmin 설치하기 PHP 4는 매우 오래전에 더 이상 지원되지 않아 보안 취약점과 호환성 문제로 인해 사용을 권장하지 않습니다만.... 가능하다면 PHP를 최신 버전으로 업그레이드하는 것이 좋습니다. 그러나 기존 시스템에서 PHP 4가 이미 설치되어 있다면 다음과 같이 phpMyAdmin을 설치할 수 있습니다. 이러한 상황에서는 보안 상의 문제에 유의해야 합니다. ​ 1. PHP 4와 웹 서버 설정 확인 먼저 PHP 4가 제대로 설치되어 있는지 확인하고, 웹 서버 (예: Apache)의 설정이 PHP 4를 지원하도록 확인합니다. ​ 2. phpMyAdmin 다운로드 phpMyAdmin의 공식 웹사이트에서 PHP 4와 호환되는 버전을 다운로드합니다. 예를 들어, 이전 버전 중에서 PHP 4를 지원하는 버전을 선택할 수 있습.. 2023. 11. 17.
[vba] Excel에서의 Randomize 함수: 무작위 값 생성의 비밀 해제 엑셀을 사용하면서 랜덤한 값을 생성해야 할 때, 가끔씩 동일한 값만이 반복되는 현상을 경험한 적이 있을 것입니다. 오늘은 그 이유와 해결책에 대해 알아보겠습니다. ​ 무작위(random) 작업을 하는 코드를 보면 Randomize라고 하는 명령어들이 가끔 나옵니다. ​ 많은 사람들은 엑셀이 당연히 계속하여 새로운 무작위 숫자를 만들거라고 생각합니다. ​ 하지만, 엑셀은 계속 같은 무작위(???) 값을 가져온다. 왜? ​ 왜냐하면, 엑셀은 내부의 랜덤한 숫자 발생기가 있고, 여기에 있는 숫자를 이용하여 랜덤한 값을 생성하는데 Randomize를 해주지 않으면 계속하여 동일한 값을 사용하기 때문입니다. ​ Randomize 함수는 랜덤 숫자 발생기의 숫자를 랜덤하게 바꾸어주어 계속하여 새로운 랜덤 값이 생성.. 2023. 11. 15.
[서식] 엑셀 자동화 양식 - 생산작업일지 및 (제품,원료)수불대장 - 떡 / 재고관리 1. 첨부한 파일은 무료이며 사용과 배포에는 제한이 없습니다. 단 출처는 꼭 남겨주세요. 2. VBA를 포함하고 있으면 매크로 사용을 허용해야 합니다. 3. View, 재료 입고, 재료 사용, 제품 거래 이력, 비율, 매핑 시트로 총 7개의 시트로 구성되어 있습니다. 4. 사용법 1) 재료 입고 - 재료 입고 시 해당하는 날짜와 해당하는 재료에 입고량을 기입합니다. (단위 Kg) 2). 제품 거래 이력 시트에 생산량 또는 출고량을 기입합니다. 3). View 탭에서 해당하는 날짜를 년, 월, 일을 기입하면 자동으로 계산된 값이 출력 됩니다. 이 값을 저장해야만 재고가 반영되므로 매일 저장을 해줍니다. 2023. 11. 8.
[무료] 파일 쉽게 암호걸기 파일에 알집등을 통해 암호를 걸 수 있으나 그와 다른 방법으로 파일 암호화 프로그램을 이용할 수 있습니다. ​ 또한 아래와 같이 윈도우 기능을 이용할 수 있습니다. ​ Windows 10 파일을 암호화하는 방법 ​ 파일 암호화는 데이터를 암호화하여 데이터를 보호할 수 있습니다. 올바른 암호화 키(예: 비밀번호)를 가진 사람만 암호 해독이 가능합니다. 파일 암호화는 Windows 10 Home에서 사용할 수 없습니다. ​ 파일 또는 폴더를 길게 누르거나 마우스 오른쪽 단추로 클릭한 다음 속성을 선택합니다. ​ 고급 버튼을 선택한 다음 데이터 보호를 위해 내용을 암호화 확인란을 선택합니다. ​ 확인을 선택하여 고급 특성 창을 닫고 적용을 선택한 다음 확인을 선택합니다. ​ 이와같이 자물쇠 모양이 나오면서 암.. 2023. 11. 4.
[vb6.0/vba] vba를 활용한 결재 도장 삽입 지식인 답변 중 기록에 남겨둘만해서 남겨봅니다. h t t p s : / / k i n . n a v e r . c o m / q n a / d e t a i l . n a v e r ? d 1 i d = 1 & d i r I d = 1 0 2 0 2 0 1 0 1 & d o c I d = 4 5 7 8 4 8 7 7 4 여기서 도형을 순서대로 "수", "우", "미", "양", "가" 로 이름을 지정합니다. 다음으로 B2 셀에 "수", "우", "미", "양", "가"를 입력 후 엔터를 치면 해당하는 칸에 이미지가 삽입됩니다. 기존 삽입된 상태이면 중복 삽입이 되지 않습니다. "수", "우", "미", "양", "가" 외에 다른 글자 즉 해당하는 이름의 도형이 없으면 작업을 자동 종료합니다. 아래는 V.. 2023. 11. 4.
[MySQL] A 테이블에 있고, B 테이블에 없는 데이터 조회 및 삭제 A테이블에 있고, B테이블에 없는 데이터 조회 SELECT * FROM `collection_and_payment` A LEFT OUTER JOIN `balhaengmul` B ON A.uid=B.rUid WHERE B.rUid IS NULL; 삭제하기 위해서는 임시테이블 사용 DELETE FROM `collection_and_payment` WHERE uid IN (SELECT * FROM (SELECT A.uid FROM `collection_and_payment` A LEFT OUTER JOIN `balhaengmul` B ON A.uid=B.rUid WHERE B.rUid IS NULL) AS temp_table); 2023. 7. 27.
[SQL] MySQL 날짜 요일(DAYOFWEEK) 구하기 및 주의사항 특정 일자의 요일을 구하고자 할 때, 사용하는 함수가 존재한다. 모든 언어에 요일을 구하는 함수가 있으며, 표준이 있기 마련이다. 일반적인 프로그래밍 언어는 전통적으로 일요일로 시작하며 0을 리턴한다. 일 월 화 수 목 금 토 0 1 2 3 4 5 6 프로그래밍 언어와 다르게 ODBC에서는 다른 값을 리턴한다. 일 월 화 수 목 금 토 1 2 3 4 5 6 7 여기서 MySQL과 MariaDB에서 제공하는 WEEKDAY()는 리턴 값이 ODBC 표준을 따르지 않는다는 점이다. 일 월 화 수 목 금 토 0 1 2 3 4 5 6 특별히 WEEKDAY()를 써야 되는 경우가 아니라면 ODBC 표준을 따르는 DAYOFWEEK()를 사용해야 실수를 줄일 수 있다. SELECT DATE_FORMAT(NOW(),"%.. 2023. 7. 25.
[MySQL] [MySQL] SELECT 문 특정 컬럼의 MIN값이 0보다 클경우 0을 반환하고 그렇지 않으면 MIN값을 반환 보통 다른 언어에서는 IF문을 사용하지만 MySQL에서는 CASE문을 사용합니다. SELECT CASE WHEN MIN(`발주번호`) - 1 > 0 THEN 0 ELSE MIN(`발주번호`) - 1 END AS V FROM `order_delivery_number` WHERE 1 위 쿼리를 실행시키면 다음과 같은 결과를 볼 수 있습니다. 2023. 7. 12.
[vba] Outlook 현재 활성화된 창의 제목 및 내용을 가져오는 방법 VBASub progrgram1472() Dim myOlExp As Outlook.Explorer Dim myOlSel As Outlook.Selection Set myOlExp = Application.ActiveExplorer Set myOlSel = myOlExp.Selection Dim selectedFolder As Outlook.MAPIFolder Set selectedFolder = myOlExp.CurrentFolder Dim itemMessage As String itemMessage = "Item is unknown." Dim expMessage As String expMessage = "Your current folder is " & selectedFolder.Parent.Name &.. 2023. 7. 10.