일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- Visual Studio 2005
- 기초
- SDK
- 문자열
- MFC
- WIN32 SDK
- Firebird
- PostgreSQL
- 인스톨
- 셋업
- VB.NET
- 파라미터
- Visual Basic
- c#
- 시리얼 통신
- 파이어버드
- Delphi
- dll
- 입문
- xml
- 소니
- 데이터베이스
- SQL
- 설치
- 예제
- 초보
- MySQL
- vb
- 델파이
- winsock
- 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;