線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:952
推到 Plurk!
推到 Facebook!

字串除錯

尚未結案
peiyao
一般會員


發表:41
回覆:23
積分:12
註冊:2003-07-21

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-11-02 22:21:21 IP:210.62.xxx.xxx 未訂閱
在memo1.text裡輸入一連串之英文字母,但一定要是Sql Server裡一為ami資料表裡面amii欄位裡一到二十列的英文字母,不然會出現錯誤訊息! 請問有高手能幫忙解答嗎??
timhuang
尊榮會員


發表:78
回覆:1815
積分:1608
註冊:2002-07-15

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-11-03 10:40:58 IP:203.95.xxx.xxx 未訂閱
可以舉個例子嗎, 說得不是很清楚. [一到二十列的英文字母]指的是二十個英文字母嗎?
peiyao
一般會員


發表:41
回覆:23
積分:12
註冊:2003-07-21

發送簡訊給我
#3 引用回覆 回覆 發表時間:2003-11-03 10:52:20 IP:210.62.xxx.xxx 未訂閱
在memo1.text裡輸入一連串之英文字母,但一定要是Sql Server裡一為ami資料表裡面amii欄位裡一到二十列的英文字母,不然會出現錯誤訊息! 用下面的圖比清楚~能幫幫忙嗎?
timhuang
尊榮會員


發表:78
回覆:1815
積分:1608
註冊:2002-07-15

發送簡訊給我
#4 引用回覆 回覆 發表時間:2003-11-04 22:54:43 IP:61.62.xxx.xxx 未訂閱
HI, 你的意思是在該 memo 中的所有的字必須是在 ami table 中的 amii 欄位中的字母是嗎?    這樣的話, 可以這樣寫:    
procedure TForm1.Button1Click(Sender: TObject);
var
  str_source: string;
  i: integer;
begin      // 先將在資料庫中允許的字元組成字串
  Query1.SQL.Text := 'select amii from ami';
  Query1.Open;
  while not Query1.Eof do
  begin
    str_source := str_source   Query1.FieldByName('amii').AsString;
    Query1.Next;
  end;      //逐一比對 memo 中的字元
  for i:= 1 to Length(Memo1.Lines.Text) do
  begin
    if (Memo1.Lines.Text[i]=#13) or (Memo1.Lines.Text[i]=#10) then Continue;
    if Pos(UpperCase(Memo1.Lines.Text[i]), UpperCase(str_source)) = 0 then
    begin
      ShowMessage('Char "' Memo1.Lines.Text[i] '" is not available!'#13#10'This character is at ' IntToStr(i) '.');
      break;
    end;
  end;      Query1.Close;
end;
peiyao
一般會員


發表:41
回覆:23
積分:12
註冊:2003-07-21

發送簡訊給我
#5 引用回覆 回覆 發表時間:2003-11-05 00:12:14 IP:219.68.xxx.xxx 未訂閱
不好意思,執行以後會出現以下之錯誤訊息耶!
pedro
尊榮會員


發表:152
回覆:1187
積分:892
註冊:2002-06-12

發送簡訊給我
#6 引用回覆 回覆 發表時間:2003-11-05 08:49:49 IP:210.61.xxx.xxx 未訂閱
您的Query.DataBase路徑沒有設好 或BDE要建立Alias
系統時間:2024-07-01 15:31:22
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!