일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 데이터베이스
- dll
- 파이어버드
- Delphi
- 인스톨
- 델파이
- 시리얼 통신
- 셋업
- 예제
- VB.NET
- Visual Studio 2005
- xml
- vb
- 파라미터
- 문자열
- 설치
- 입문
- SDK
- MySQL
- WIN32 SDK
- 초보
- PostgreSQL
- winsock
- 기초
- 소니
- Visual Basic
- SQL
- MFC
- Firebird
- c#
- Today
- Total
프로그래밍 노트
델파이 : 클립보드의 데이터를 StringGrid에 붙이기 본문
클립보드의 데이터를 StringGrid에 붙이기
엑셀에서 데이터를 카피해서 StringGrid에 붙이기
클립보드의 데이터를 쓰기위해서는
uses절에 Clipbrd 를 추가해야 된다.
procedure TfrmCable.PasteToGrid(sgrdPaste: TStringGrid;
iCol, iRow: integer);
const
cTab = #9;
cCR = #13;
cLF = #10;
var
iCols : integer;
iRows : integer;
i : integer;
sClip : string;
sSubs : string;
begin
// Col,Row 이 음수 일때는 0으로
if iCol < 0 then iCol := 0;
if iRow < 0 then iRow := 0;
sClip := Clipboard.AsText;
iCols := 0;
iRows := 0;
sSubs := '';
for i := 1 to Length(sClip) do
begin
case sClip[i] of
cTab:
begin
if (iCol + iCols < sgrdPaste.ColCount) and
(iRow + iRows < sgrdPaste.RowCount) then
sgrdPaste.Cells[iCol + iCols, iRow + iRows] := sSubs;
Inc(iCols);
sSubs := '';
end;
cCR:
begin
if (iCol + iCols < sgrdPaste.ColCount) and
(iRow + iRows < sgrdPaste.RowCount) then
sgrdPaste.Cells[iCol + iCols, iRow + iRows] := sSubs;
iCols := 0;
Inc(iRows);
sSubs := '';
end;
cLF: ;
else
begin
sSubs := sSubs + sClip[i];
end;
end;
end;
end;