gpt4 book ai didi

c# - 如何本地化 DataTable 列名称

转载 作者:太空狗 更新时间:2023-10-29 23:35:23 25 4
gpt4 key购买 nike

这是我的数据表

public static DataTable GetTableForApproval()
{
using (var connection = Utils.Database.GetConnection())
using (var command = new SqlCommand("SELECT [UserID], [Username], " +
"[Email], [Role], [Date] FROM [Users] WHERE [Role] = @role",
connection))
{
command.Parameters.AddWithValue("@role", "Waiting");
using (var reader = command.ExecuteReader())
{
var table = new DataTable();

table.Columns.Add("UserID", typeof(int));
table.Columns.Add("Name", typeof(string));
table.Columns.Add("Email", typeof(string));
table.Columns.Add("Role", typeof(string));
table.Columns.Add("Registration date", typeof(DateTime));

if (reader != null)
{
while (reader.Read())
{
table.Rows.Add((int)reader["UserID"],
(string)reader["Username"], (string)reader["Email"],
(string)reader["Role"], (DateTime)reader["Date"]);
}
}
return table;
}
}
}

我想本地化列名称。你能告诉我我该怎么做吗?我本地化了我的 .aspx 页面,但我不知道如何本地化 .cs 文件中的文本。

最佳答案

将 resx 文件添加到项目后,Visual Studio 会生成允许访问它们的强类型类。例如,如果您将 Messages.resx 添加到您的项目中,将创建一个 Messages 静态类:

table.Columns.Add(Messages.UserId, typeof(int));

其中 UserId 是您添加的字符串资源。

更好的解决方案是本地化用户界面而不是 DataTable 的列名。这是一个例子:

<%@ Page Language="C#" AutoEventWireup="true"  %>
<script type="text/C#" runat="server">
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
var table = new System.Data.DataTable();
table.Columns.Add("UserID", typeof(int));
for (int i = 0; i < 10; i++)
{
table.Rows.Add(i);
}
grdTest.DataSource = table;
grdTest.DataBind();
}
}
</script>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title></title>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:GridView ID="grdTest" runat="server" AutoGenerateColumns="false">
<Columns>
<asp:BoundField DataField="UserID"
HeaderText="default value"
meta:resourcekey="Grid" />
</Columns>
</asp:GridView>
</div>
</form>
</body>
</html>

页面上有一个 GridView 绑定(bind)到具有单列的 DataTable。注意 BoundField 上的 meta:resourcekey="Grid" 属性。现在将特殊的 App_LocalResources 文件夹添加到您的 Web 应用程序,并在其中添加一个名为 Default.aspx.resx 的资源文件,假设该网页名为 Default.aspx。在里面你可以添加以下字符串资源:

Grid.HeaderText  |  Some value

标记中给定的 HeaderText 的默认值将替换为资源文件中的默认值,前提是它存在。

关于c# - 如何本地化 DataTable 列名称,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2348064/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com