php打印表格数据 php打印数据类型

dump方法打印表格在多人合作项目中偶尔会遇到这样的情况:
现在在调试程序,从其他小伙伴提供的方法中取到的table类型数据报错了,此时我们想检查一下数据格式 。但是直接print又无法打印出来这个table的结构,真机测试时又不太方便在Lua中打断点 , 用for循环来输出又不能展开所有子table(有个dump工具该多好) 。
所以,如果想解决上面的问题 , 将整个table类型数据的结构输出到控制台 , 那就使用循环 递归的方式来输出数据吧 。
下面直接贴上代码以及测试用例:
感谢老司机Reyn在评论中提出的建议
--[[
print_dump是一个用于调试输出数据的函数,能够打印出nil,boolean,number,string,table类型的数据 , 以及table类型值的元表
参数data表示要输出的数据
参数showMetatable表示是否要输出元表
参数lastCount用于格式控制 , 用户请勿使用该变量
]]
function print_dump(data, showMetatable, lastCount)
if type(data) ~= "table" then
--Value
if type(data) == "string" then
io.write("\"", data, "\"")
else
io.write(tostring(data))
end
else
--Format
local count = lastCount or 0
count = count1
io.write("{\n")
--Metatable
if showMetatable then
for i = 1,count do io.write("\t") end
local mt = getmetatable(data)
io.write("\"__metatable\" = ")
print_dump(mt, showMetatable, count)-- 如果不想看到元表的元表,可将showMetatable处填nil
io.write(",\n")--如果不想在元表后加逗号,可以删除这里的逗号
end
--Key
for key,value in pairs(data) do
for i = 1,count do io.write("\t") end
if type(key) == "string" then
io.write("\"", key, "\" = ")
elseif type(key) == "number" then
io.write("[", key, "] = ")
else
io.write(tostring(key))
end
print_dump(value, showMetatable, count) -- 如果不想看到子table的元表,可将showMetatable处填nil
io.write(",\n")--如果不想在table的每一个item后加逗号,可以删除这里的逗号
end
--Format
for i = 1,lastCount or 0 do io.write("\t") end
io.write("}")
end
--Format
if not lastCount then
io.write("\n")
end
end
下面分别输出了nil,boolean,number,string,table类型的数据,测试代码如下:
print("---------------Test---------------")
local myData = https://www.04ip.com/post/nil
print_dump(myData)
print("-------------------")
myData = https://www.04ip.com/post/true
print_dump(myData)
print("-------------------")
myData = https://www.04ip.com/post/10086
print_dump(myData)
print("-------------------")
myData = "https://www.04ip.com/post/your name"
print_dump(myData)
print("-------------------")
myData = https://www.04ip.com/post/{
null = nil,
bool = true,
num = 20,
str = "abc",
subTab = {"111", "222"},
func = print_dump,
sunTab = {"sun_a", {"sun_1", "sun_2"}, {you = "god", i = "man"}}
}
local mt = {}
mt.__add = function(op1, op2) return 1000 end
mt.__index = {1,2}
setmetatable(myData, mt)
print_dump(myData, 1) -- 第二个参数不为空则打印元表
print("---------------End---------------")
dump输出的结果是这样的(因为内容太长 , 屏幕高度不够,所以分成了两张图):
【php打印表格数据 php打印数据类型】上半部分输出.jpeg
下半部分输出.jpeg
如果不是有特殊需求,建议按照注释的提示,屏蔽子级table类型值的元表 。屏蔽子级table类型值的元表之后输出看起来清爽很多 。
屏蔽子级table的元表后的输出.jpeg
总结:
其实解决问题不难,需求是成长的直接动力 。
其实为了dump输出图上的效果 , 我还是花了一些时间去做微调 。最初末尾是没有换行的,也就是End那一行会紧接着上一行输出,虽然table的结构可以正常看到 , 但是如果dump的不是一个table,那就看着很奇怪了 。时间总是花在细节上 。
php打印表格这个目前没有太好的办法 , 也许你打印时跳到一个新窗口去,把表格重新做一下,做到一个页面里来,这样打印就有自己的样式了
php输出表格table
tr
?php
$trnum = 50;//表格的行数
$tdnum = 10 ;//表格的列数
$trend = $tdnum - 1; //表格换行
$tdwid = (int)(100 / $tdnum); //计算表格列的宽度
for ($i=1;$i=$trnum;$i) {//循环表格行
$k = $i * $tdnum - $trend ;//循环表格换行公式
$l = $i * $tdnum ;//循环表格列数公式
echo "tr";//输出表格行开始
for ($j=$k;$j=$l;$j) {//循环表格列
echo "td width='{$tdwid}%' {$j}/td";//输出表格列
}
echo "/tr";//输出表格行结束
}
?
/tr
/table
PHP如何将数据库表中的某列数据一个一个循环取出并打印一般我们为了减少数据库链接,取数据是一次取出所有想要的数据然后做循环处理,而不是一个个循环取出
$servername = "localhost";
$username = "root";
$password = "root";
$dbname = "aaaa";
// 创建连接
$conn = new mysqli($servername, $username, $password, $dbname);
// Check connection
if ($conn-connect_error) {
die("连接失败: " . $conn-connect_error);
}
$conn-query('set names utf8');
$sql = "SELECT name FROM xiao ";//这里是查询xiao表的name列的所有数据
$result = $conn-query($sql);
if ($result-num_rows0) {
// 输出数据
while($row = $result-fetch_assoc()) {
//print_r($row);
echo "name: " . $row["name"]."br";//这里是循环打印
}
} else {
echo "没有查询到数据";
}
$conn-close();
PHP如何查询点“查询”后整体输出表格用ajax来做,点查询,发送请求到查询数据库数据的页面 , 在请求的页面echo出来(这就是数据),js里指明表格在网页哪个结构里显示,比如在一个class为d的div里面就这样,$('.d').html(返回的数据);
结合你的代码就是把打印表格的那部分扔到查询出数据的时候的后面,如果你的数据库操作写成的类,就不要这么做,则写一个php调用数据库操作类的查数据方法,然后接着打印,接着就是js了 , 我前面已经说了怎么做
php打印表格数据的介绍就聊到这里吧,感谢你花时间阅读本站内容 , 更多关于php打印数据类型、php打印表格数据的信息别忘了在本站进行查找喔 。

    推荐阅读