rss 뉴스제목글을 지정된 언론사별로 가져와서 홈페이지에 출력하려고 합니다.
아래 코드처럼 짜집기를 했는데
일단, 언론사별 rss 뉴스제목를 가져와서 출력이 되는거 까지는 이상이 없습니다
문제는...
아래 코드처럼 하면 ... 있는대로 다 가져오다 보니 약 100여개의 '뉴스제목'이 출력 되어버립니다.
홈페이지에는 '최신시간'순으로 or '기타'기준으로...
언론사구분없이 통틀어서 10여개 정도의 rss 뉴스제목만 홈페이지에 출력하고 싶습니다.
코드의 어느부분을 어떻게 손봐야 할런지요...??
도움글을 좀 부탁드립니다.
---------- 코드참고 ------------------------
$news = array(
"sports" => array("스포츠서울","http://www.sportsseoul.com/rss/rss.asp?cp_flag=1&cat_flag=1"),
"ohmynews" => array("오마이뉴스","http://rss.ohmynews.com/rss/ohmynews.xml"),
"chosun" => array("조선일보","http://newsplus.chosun.com/hitdata/xml/index/index.xml"),
"hani" => array("한겨레신문","http://www.hani.co.kr/rss/newsrank/"),
"kbench" => array("케이벤치","http://rss.kbench.com/news.xml"),
"YTN뉴스" => array("YTN","http://www.yonhapnews.co.kr/RSS/sokbo.xml")
);
"sports" => array("스포츠서울","http://www.sportsseoul.com/rss/rss.asp?cp_flag=1&cat_flag=1"),
"ohmynews" => array("오마이뉴스","http://rss.ohmynews.com/rss/ohmynews.xml"),
"chosun" => array("조선일보","http://newsplus.chosun.com/hitdata/xml/index/index.xml"),
"hani" => array("한겨레신문","http://www.hani.co.kr/rss/newsrank/"),
"kbench" => array("케이벤치","http://rss.kbench.com/news.xml"),
"YTN뉴스" => array("YTN","http://www.yonhapnews.co.kr/RSS/sokbo.xml")
);
$ns = $HTTP_GET_VARS["ns"];
if(empty($ns)){ $ns = array_keys($news); }
if(empty($ns)){ $ns = array_keys($news); }
$newsList = array();
while (list($key, $value) = each ($news)) {
$url = $value[1];
$rss = new RSSReader($url,true,60,$DOCUMENT_ROOT."/newsmowa/cache");
$response = $rss->Read();
while (list($key, $value) = each ($news)) {
$url = $value[1];
$rss = new RSSReader($url,true,60,$DOCUMENT_ROOT."/newsmowa/cache");
$response = $rss->Read();
foreach($rss->getItems() as $item){
if(isChoice($key)){
if(isset($item["dc:date"])) $item["pubdate"] = $item["dc:date"];
//array_push($newsList,array($value[0],$item["title"],$item["link"],$item["description"],$item["pubdate"]));
array_push($newsList,
array(
NAME => $value[0],
TITLE => $item["title"],
LINK => $item["link"],
DESCRIPTION => $item["description"],
PUBDATE => $item["pubdate"],
TOPUBDATE => _Topubdate($item["pubdate"]),
IDXPUBDATE => _Topubdate($item["pubdate"],"YmdHis")
)
);
}
}
if(isset($item["dc:date"])) $item["pubdate"] = $item["dc:date"];
//array_push($newsList,array($value[0],$item["title"],$item["link"],$item["description"],$item["pubdate"]));
array_push($newsList,
array(
NAME => $value[0],
TITLE => $item["title"],
LINK => $item["link"],
DESCRIPTION => $item["description"],
PUBDATE => $item["pubdate"],
TOPUBDATE => _Topubdate($item["pubdate"]),
IDXPUBDATE => _Topubdate($item["pubdate"],"YmdHis")
)
);
}
}
$rss->free();
unset($rss);
}
unset($rss);
}
usort($newsList,"cmp");
echo "<html><head><title>뉴스모와</title>\n";
echo "<style><!-- BODY,TD,SELECT { FONT: 9pt Arial; LINE-HEIGHT: 17px;} //--></style>\n";
echo "<body>";
echo "<form>";
echo "<table width=100% border=1>\n";
echo "<tr><td>\n";
echo "<style><!-- BODY,TD,SELECT { FONT: 9pt Arial; LINE-HEIGHT: 17px;} //--></style>\n";
echo "<body>";
echo "<form>";
echo "<table width=100% border=1>\n";
echo "<tr><td>\n";
foreach($news as $key => $value) {
$checked = isChoice($key)? "checked":"";
echo "<input type=checkbox name=ns[] value=$key $checked> $value[0]\n";
}
echo "<input type=submit value=\"조회\"></td></tr>\n";
echo "</table>";
echo "</form>";
echo "</table>";
echo "</form>";
echo "<table width=100% border=0>\n";
echo "<tr><td align=center>뉴스제목</td><td align=center>출처</td><td align=center>발행일</td></tr>\n";
foreach($newsList as $list){
printf("<tr><td><a href=\"%s\" target=_blank>%s</td><td align=center>%s</td><td align=center>%s</td></tr>\n",
$list[LINK],$list[TITLE],$list[NAME],$list[TOPUBDATE]);
}
echo "</table>";
echo "<tr><td align=center>뉴스제목</td><td align=center>출처</td><td align=center>발행일</td></tr>\n";
foreach($newsList as $list){
printf("<tr><td><a href=\"%s\" target=_blank>%s</td><td align=center>%s</td><td align=center>%s</td></tr>\n",
$list[LINK],$list[TITLE],$list[NAME],$list[TOPUBDATE]);
}
echo "</table>";
echo "</body></html>\n";
?>
?>
댓글 1개
영리한바부
13년 전
이미 처리 하셨는지 모르겠는데 혹시 해결하지 못하셨다면
참고 해서 수정해보십시요
// xml결과값을 모두 배열에 저장구현
// 다중배열 정렬
foreach (뉴스배열 as $key => $row) {
$sort[$key] = $row[' IDXPUBDATE'];
}
array_multisort($sort, SORT_ASC, 뉴스배열); // SORT_ASC , SORT_DESC
// 원하는 수만큼 뉴스 출력구현
http://php.net/manual/en/function.array-multisort.php
참고 해서 수정해보십시요
// xml결과값을 모두 배열에 저장구현
// 다중배열 정렬
foreach (뉴스배열 as $key => $row) {
$sort[$key] = $row[' IDXPUBDATE'];
}
array_multisort($sort, SORT_ASC, 뉴스배열); // SORT_ASC , SORT_DESC
// 원하는 수만큼 뉴스 출력구현
http://php.net/manual/en/function.array-multisort.php
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 230 | 20년 전 | 2087 | ||
| 229 | 20년 전 | 3148 | ||
| 228 | 20년 전 | 3340 | ||
| 227 | 20년 전 | 2416 | ||
| 226 | 20년 전 | 5497 | ||
| 225 | 20년 전 | 2534 | ||
| 224 | 20년 전 | 2980 | ||
| 223 | 20년 전 | 4212 | ||
| 222 | 20년 전 | 2612 | ||
| 221 | 20년 전 | 2302 | ||
| 220 | 20년 전 | 3690 | ||
| 219 | 20년 전 | 2083 | ||
| 218 | 20년 전 | 3584 | ||
| 217 | 20년 전 | 2495 | ||
| 216 | 20년 전 | 2932 | ||
| 215 | 20년 전 | 2241 | ||
| 214 | 20년 전 | 3350 | ||
| 213 | 20년 전 | 2930 | ||
| 212 | 20년 전 | 3073 | ||
| 211 | 20년 전 | 2158 | ||
| 210 | 20년 전 | 1928 | ||
| 209 | 20년 전 | 2374 | ||
| 208 | 20년 전 | 2003 | ||
| 207 | 20년 전 | 1691 | ||
| 206 | 20년 전 | 1865 | ||
| 205 | 20년 전 | 3958 | ||
| 204 | 20년 전 | 1684 | ||
| 203 | 20년 전 | 2023 | ||
| 202 | 20년 전 | 2366 | ||
| 201 | 20년 전 | 1839 | ||
| 200 | 20년 전 | 2969 | ||
| 199 | 20년 전 | 2012 | ||
| 198 | 20년 전 | 2096 | ||
| 197 | 20년 전 | 3667 | ||
| 196 | 20년 전 | 3007 | ||
| 195 | 20년 전 | 2118 | ||
| 194 | 20년 전 | 10269 | ||
| 193 | 20년 전 | 2263 | ||
| 192 | 20년 전 | 1615 | ||
| 191 | 20년 전 | 2678 | ||
| 190 | 20년 전 | 2300 | ||
| 189 | 20년 전 | 1701 | ||
| 188 | 20년 전 | 1504 | ||
| 187 | 20년 전 | 1923 | ||
| 186 | 20년 전 | 1749 | ||
| 185 | 20년 전 | 1794 | ||
| 184 | 20년 전 | 2379 | ||
| 183 | 20년 전 | 1588 | ||
| 182 | 20년 전 | 1497 | ||
| 181 | 20년 전 | 1638 | ||
| 180 | 20년 전 | 2737 | ||
| 179 | 20년 전 | 1824 | ||
| 178 | 20년 전 | 1874 | ||
| 177 | 20년 전 | 2002 | ||
| 176 | 20년 전 | 1811 | ||
| 175 | 20년 전 | 1878 | ||
| 174 | 20년 전 | 1708 | ||
| 173 | 20년 전 | 2067 | ||
| 172 | 20년 전 | 1793 | ||
| 171 | 20년 전 | 2576 | ||
| 170 | 20년 전 | 2297 | ||
| 169 | 20년 전 | 2572 | ||
| 168 | 20년 전 | 1507 | ||
| 167 | 20년 전 | 1598 | ||
| 166 | 20년 전 | 2170 | ||
| 165 | 20년 전 | 1655 | ||
| 164 | 20년 전 | 3789 | ||
| 163 | 20년 전 | 2687 | ||
| 162 | 20년 전 | 2104 | ||
| 161 | 20년 전 | 2816 | ||
| 160 | 20년 전 | 1755 | ||
| 159 | 20년 전 | 1631 | ||
| 158 | 20년 전 | 2582 | ||
| 157 | 20년 전 | 1511 | ||
| 156 | 20년 전 | 1770 | ||
| 155 | 20년 전 | 3245 | ||
| 154 | 20년 전 | 1919 | ||
| 153 | 20년 전 | 1636 | ||
| 152 | 20년 전 | 4973 | ||
| 151 | 20년 전 | 4593 | ||
| 150 | 20년 전 | 3535 | ||
| 149 | 20년 전 | 3816 | ||
| 148 | 20년 전 | 7099 | ||
| 147 | 20년 전 | 3568 | ||
| 146 | 20년 전 | 2647 | ||
| 145 | 20년 전 | 2638 | ||
| 144 | 20년 전 | 7177 | ||
| 143 | 20년 전 | 4623 | ||
| 142 | 20년 전 | 1909 | ||
| 141 | 20년 전 | 3259 | ||
| 140 | 20년 전 | 1979 | ||
| 139 | 20년 전 | 1612 | ||
| 138 | 20년 전 | 2328 | ||
| 137 | 20년 전 | 1799 | ||
| 136 | 20년 전 | 1468 | ||
| 135 | 20년 전 | 1806 | ||
| 134 | 20년 전 | 2983 | ||
| 133 | 20년 전 | 2471 | ||
| 132 | 20년 전 | 1714 | ||
| 131 | 20년 전 | 1666 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기