Foruma yeni üye oldum ve 2 tane sorum olacaktı:
1-)StringGrid'ten TChart componenti ile grafik elde ediyorum ancak X koordinatını(BottomAxis)'i benim istediğim bir tarihten(Yalnızca yıl olarak) başlayıp artmasını istiyorum ancak tarih olayını açtığımda ay veya gün olarak artıyor. #,##1950,### şeklinde olduğunda ya da değişik kombinasyonlar denediğimde ise 1950'yi String olarak alıp 19501... olarak algılıyor. bununla ilgili yapmam gereken şey nedir?
2-)Excel'e aktarım olarak
Kod: Tümünü seç
procedure XlsWriteCellLabel(XlsStream: TStream; const ACol, ARow: Word;
const AValue: string);
var
L: Word;
const
{$J+}
CXlsLabel: array[0..5] of Word = ($204, 0, 0, 0, 0, 0);
{$J-}
begin
L := Length(AValue);
CXlsLabel[1] := 8 + L;
CXlsLabel[2] := ARow;
CXlsLabel[3] := ACol;
CXlsLabel[5] := L;
XlsStream.WriteBuffer(CXlsLabel, SizeOf(CXlsLabel));
XlsStream.WriteBuffer(Pointer(AValue)^, L);
end;
function SaveAsExcelFile(SG: TStringGrid; AFileName: string): Boolean;
const
{$J+} CXlsBof: array[0..5] of Word = ($809, 8, 00, $10, 0, 0); {$J-}
CXlsEof: array[0..1] of Word = ($0A, 00);
var
FStream: TFileStream;
I, J: Integer;
begin
Result := False;
FStream := TFileStream.Create(PChar(AFileName), fmCreate or fmOpenWrite);
try
CXlsBof[4] := 0;
FStream.WriteBuffer(CXlsBof, SizeOf(CXlsBof));
for i := 0 to SG.ColCount - 1 do
for j := 0 to SG.RowCount - 1 do
XlsWriteCellLabel(FStream, I, J, SG.cells[i, j]);
FStream.WriteBuffer(CXlsEof, SizeOf(CXlsEof));
Result := True;
finally
FStream.Free;
end;
end;
Kod: Tümünü seç
procedure TForm1.BitBtn1Click(Sender: TObject);
begin
if SaveAsExcelFile(STringGrid, 'C:\' + edit1.text + '.xls') then
ShowMessage(edit1.text + ' isimli dosya C:\`ye kaydedilmistir');
end;
Kod: Tümünü seç
XLApp.Workbooks.Open('C:\' + edit1.text + '.xls')
Yardımlarınız için teşekkür ederim...
Veysel GÜMÜŞ