Datalist分页代码

<%@ Page Language="c#" ResponseEncoding="gb2312" %>
<%@ Import Namespace="System.Data" %>
<%@ Import Namespace="System.Data.SqlClient" %>
<Script Language="C#" runat="server">
    
int PageSize;
    
int RecordCoutn;
    
int pageCount;
    
int CurrentPage;
    SqlConnection conn;
    
void Page_Load(object sender, EventArgs e)
    
{
        connOpen();
        PageSize 
= 2;
        
if (!IsPostBack)
        
{
            mathBd();
            CurrentPage 
= 0;
            RecordCoutn
=CalculateRecord();
            
this.lblRecordCount.Text=RecordCoutn.ToString();
            pageCount 
= RecordCoutn / PageSize;
            
this.lblPageCount.Text = pageCount.ToString();
            ViewState[
"PageIndex"= 0;
            ViewState[
"PageCount"= pageCount;
            DropDown();

        }

    }

    
private void connOpen()
    
{
        conn 
= new SqlConnection("server=ss/sqlexpress;database=Northwind;uid=sa;pwd=;");
        conn.Open(); 
    }

    
private void mathBd()
    
{
        
int startIndex;
        startIndex
=PageSize*CurrentPage;
        SqlDataAdapter sdr
=new SqlDataAdapter ("select * from Employees",conn);
        DataSet ds
=new DataSet ();
        sdr.Fill(ds,startIndex,PageSize,
"Employees");
        
this.MyDataGrid.DataSource=ds.Tables["Employees"].DefaultView;
        
this.MyDataGrid.DataBind();

        lbnFirstPage.Enabled 
= true;
        lbnNextPage.Enabled 
= true;
        lbnPrevPage.Enabled 
= true;
        lbnLastPage.Enabled 
= true;
        
if (CurrentPage == (pageCount-1))
        
{
            lbnNextPage.Enabled 
= false;
            lbnLastPage.Enabled 
= false;
        }

        
if (CurrentPage == 0)
        
{

            lbnFirstPage.Enabled 
= false;
            lbnPrevPage.Enabled 
= false;
        }

        
this.Label2.Text = (CurrentPage + 1).ToString();
        ViewState[
"PageIndex"= CurrentPage;
    }

    
public  int CalculateRecord()
    
{
        
int intRecord;
        
string strComm = "select count (*) as co from Employees";
        SqlCommand comm 
= new SqlCommand(strComm, conn);
        SqlDataReader dr 
= comm.ExecuteReader();
        
if (dr.Read())
        
{
            intRecord 
= Convert.ToInt32(dr["co"].ToString());
        }

        
else
        
{
            intRecord 
= 0
        }

        dr.Close();
        
return intRecord;
    }

    
private void Page_OnClick(object sender, CommandEventArgs e)
    
{
        CurrentPage 
=(int) ViewState["PageIndex"];
        pageCount
=(int)ViewState["PageCount"];
        
string cmd = e.CommandName;
        
switch (cmd)
        
{
            
case "next":
                
if (CurrentPage < (pageCount-1)) CurrentPage++break;
            
case"prev":
                
if (CurrentPage > 0) CurrentPage--break;
            
case"last":
                CurrentPage 
= pageCount - 1break;
            
default:
                CurrentPage 
= System.Convert.ToInt32(cmd); break;
        }

        ViewState[
"PageIndex"= CurrentPage;
        
//myDropDownList.SelectedIndex = CurrentPage;
        mathBd();
    }

    
private void DropDown()
    
{
        
for (int u = 0; u < pageCount; u++)
        
{
            myDropDownList.Items.Add(
new ListItem(""+(u + 1).ToString() + "", Convert.ToString(u)));
        }
 
    }

    
private void listchanged(object sender, EventArgs e)
    
{
        CurrentPage 
= myDropDownList.SelectedIndex;
        mathBd(); 
    }

</Script>
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
<title>Datalist 分页</title>
</head>
<body>
<form id="Form1" runat="server">

<asp:DataList id="MyDataGrid" runat="server"
HeaderStyle
-BackColor="#aaaadd"
AlternatingItemStyle
-BackColor="Gainsboro"
EditItemStyle
-BackColor="yellow"
>
 
<ItemTemplate>
  姓名:
<%# DataBinder.Eval(Container.DataItem,"EmployeeID"%>
 
</ItemTemplate>
</asp:DataList>
共有
<asp:Label id="lblRecordCount" ForeColor="red" runat="server" />条记录&nbsp;
当前为
<asp:Label id="Label2" ForeColor="red" runat="server" />/<asp:Label id="lblPageCount" ForeColor="red" runat="server" />&nbsp;
&nbsp;
    
<br />
   
<hr />
    
<asp:LinkButton ID="lbnFirstPage" runat="server" CommandName="0" OnCommand="Page_OnClick">首页</asp:LinkButton>
    
<asp:LinkButton ID="lbnPrevPage" runat="server" CommandName="prev" OnCommand="Page_OnClick">上页</asp:LinkButton>
    
<asp:LinkButton ID="lbnNextPage" runat="server" CommandName="next" OnCommand="Page_OnClick">下页</asp:LinkButton>
    
<asp:LinkButton ID="lbnLastPage" runat="server" CommandName="last" OnCommand="Page_OnClick">未页</asp:LinkButton>
    
<asp:DropDownList ID="myDropDownList" runat="server" AutoPostBack="true" OnSelectedIndexChanged="listchanged">
</asp:DropDownList>

</form>
</body>
</html>

 
内容概要:本文系统介绍了算术优化算法(AOA)的基本原理、核心思想及Python实现方法,并通过图像分割的实际案例展示了其应用价值。AOA是一种基于种群的元启发式算法,其核心思想来源于四则运算,利用乘除运算进行全局勘探,加减运算进行局部开发,通过数学优化器加速函数(MOA)和数学优化概率(MOP)动态控制搜索过程,在全局探索与局部开发之间实现平衡。文章详细解析了算法的初始化、勘探与开发阶段的更新策略,并提供了完整的Python代码实现,结合Rastrigin函数进行测试验证。进一步地,以Flask框架搭建前后端分离系统,将AOA应用于图像分割任务,展示了其在实际工程中的可行性与高效性。最后,通过收敛速度、寻优精度等指标评估算法性能,并提出自适应参数调整、模型优化和并行计算等改进策略。; 适合人群:具备一定Python编程基础和优化算法基础知识的高校学生、科研人员及工程技术人员,尤其适合从事人工智能、图像处理、智能优化等领域的从业者;; 使用场景及目标:①理解元启发式算法的设计思想与实现机制;②掌握AOA在函数优化、图像分割等实际问题中的建模与求解方法;③学习如何将优化算法集成到Web系统中实现工程化应用;④为算法性能评估与改进提供实践参考; 阅读建议:建议读者结合代码逐行调试,深入理解算法流程中MOA与MOP的作用机制,尝试在不同测试函数上运行算法以观察性能差异,并可进一步扩展图像分割模块,引入更复杂的预处理或后处理技术以提升分割效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值