C#で とってきた値で表示する記号をswich文でかきました
この◇や●の記号を最終的に表にしたいです。
ヘッダーである暴風雪や大雨
表のイメージとしては
横が 暴風雪 大雨 暴風 …とヘッダーで
縦のヘッダー? が"area_name"です。
この時ただ1行ずつ表示するのではなく
"area_code"("area_name")が同じであれば1行で◇などの記号を表示させ、違うのならば次の下の列
にまた"area_name"を出力しその行にまた出力します
boufuusetsuやooameに値を格納?し表として表示させたいのですがわかりません。
また
"alert","area_name","area_code"
"alert_status_code"
"alert_short_name"
などはSQLでデータベースからとってきた値です。
何が大雨のデータ、洪水のデータなどかは"alert_short_name"で判断させればいいと思っています
プログラム初心者で質問もよくわからないかと思いますが、助けて!いただきたいです。
よろしくお願いします。
追記
質問の仕方、またこのサイトを利用し始めたばかりで使い方がよくわかっていなくて申し訳ありません
使用しているのはVS2010です
プロジェクトの種類ですが、おそらくWEBサイトです
とってきたデータをHTMLファイルにしたいです。
データを表形式で出力させるためforeach文でループさせているのですが、うまくかけません
また、swich文のcaseのところで
「コントロールはひとつの case ラベル (case "0") から別のラベルへ流れ落ちることはできません」
の解決策がわかりません
最終的にはHTMLで表を出力させたいのですが
イメージとしては
このような表にしたいです
うまく伝えられなくて申し訳ないです
C#
1 2 3if (ds.Tables[tblname].Rows.Count > 0) 4 { 5 6 7 8 sw.Write("<table border=1>"); 9 sw.Write("<tr><td> </td><td>暴風雪</td><td>大雨</td><td>暴風</td><td>大雪</td><td>波浪</td><td>高潮</td><td>洪水</td><td>雪</td><td>融雪</td><td>濃霧</td><td>乾燥</td><td>なだれ</td><td>低温</td><td>霧</td><td>着雪</td><td>着氷</td></tr>");//表のヘッダー 10 11 12 13 string oldCode = string.Empty; 14 15 string boufuusetsu = string.Empty; 16 string ooame = string.Empty; 17 string bouhuu = string.Empty; 18 string ooyuki = string.Empty; 19 string haro = string.Empty; 20 string takashio = string.Empty; 21 string kouzui = string.Empty; 22 string yuki = string.Empty; 23 string yuusetsu = string.Empty; 24 string noumu = string.Empty; 25 string kanso = string.Empty; 26 string nadare = string.Empty; 27 string teion = string.Empty; 28 string kiri = string.Empty; 29 string chakuhyo = string.Empty; 30 string chakusetsu = string.Empty; 31 32 foreach (DataRow row in ds.Tables[tblname].Rows) 33 { 34 35 36 string work = row["area_name"].ToString(); 37 string code = row["area_cd"].ToString(); 38 string work4 = row["alert"].ToString();//番号 39 string work5 = row["alert_status_code"].ToString();//発表とか 40 string work6 = row["alert_short_name"].ToString();//雷、暴風とか 41 42 switch(work5) 43 { 44 case "0"://発表 45 switch(work4){ 46 case "32": 47 case "33": 48 case "35": 49 case "36": 50 case "37": 51 case "38": 52 sw.Write("◆");//特別警報 53 break; 54 case "02": 55 case "03": 56 case "04": 57 case "05": 58 case "06": 59 case "07": 60 case "08": 61 sw.Write("●");//警報 62 break; 63 case "13": 64 case "10": 65 case "18": 66 case "15": 67 case "12": 68 case "16": 69 case "19": 70 case "14": 71 case "17": 72 case "20": 73 case "21": 74 case "22": 75 case "23": 76 case "24": 77 case "25": 78 case "26": 79 case "27": 80 sw.Write("▲");//注意報警報 81 break; 82 } 83 84 case "1"://警報から注意報 85 switch(work4){ 86 case "00": 87 88 sw.Write("▽"); 89 break; 90 } 91 case "2"://継続 92 switch(work4){ 93 case "32": 94 case "33": 95 case "35": 96 case "36": 97 case "37": 98 case "38": 99 sw.Write("◇");//特別警報 100 break; 101 case "02": 102 case "03": 103 case "04": 104 case "05": 105 case "06": 106 case "07": 107 case "08": 108 sw.Write("○");//特別警報 109 break; 110 case "13": 111 case "10": 112 case "18": 113 case "15": 114 case "12": 115 case "16": 116 case "19": 117 case "14": 118 case "17": 119 case "20": 120 case "21": 121 case "22": 122 case "23": 123 case "24": 124 case "25": 125 case "26": 126 case "27": 127 sw.Write("△");//特別警報 128 break; 129 } 130 131 case "3"://解除 132 switch(work4){ 133 case "00": 134 sw.Write("×"); 135 break; 136 } 137 case "4"://特別警報から警報 138 switch(work4){ 139 case "": 140 sw.Write("▼"); 141 break; 142 } 143 case "5"://警報から注意報 144 switch(work4){ 145 case "": 146 sw.Write("▽"); 147 break; 148 } 149 } 150 if (code == oldCode) 151 { 152 sw.Write("<td>" + work + "</td><td>" +work6+ "</td>"); 153 oldCode = code; 154 155 } 156 else 157 { 158 sw.Write("<tr><td>" + work + "</td><td>" +work6+ "</td></tr>"); 159 oldCode = code; 160 } 161 162 } 163 sw.Write("</table>"); 164 }
回答1件
あなたの回答
tips
プレビュー