filesize返回的是以字节为单位的数据也可以使之处理数字

1.文件的属性信息获取

首先文件具有类型,在linux下边,有block(块设备,如磁盘分区、CD-ROM)、char(以字符为输入的设备,如键盘、打印机)、dir(目录类型,目录也是文件的一种)、fifo(命名管道,解释是将信息从一个进程传到另一个进程)、file(普通的文件)、link(链接,类似win下边的快捷方式)、unknow(未知类型)7大类,在win下边,只有3类:file、dir和unknown。Linux渣表示一定要好好搞一下Linux-_-,人家完全是为Linux而生。

关于类型的获取有这么几个函数:filetype:获取类型; is_file:判断为是否是正常文件; is_link:判断是否是链接。

关于属性的获取有这么几个函数:

file_exists:判断文件或目录是否存在;

filesize:获取文件大小;

is_readable、is_writable、is_executable :是否可读、可写、可执行;

filectime、filemtime、fileatime:获取文件的创建时间(create)、修改时间(modify)、访问时间(access),均返回时间戳;

stat:获取文件的一些基本信息,返回一个索引与关联混合数组。

比如,可以这样判断文件类型:

复制代码

<php

function getFileType($path){ // 获取文件类型

switch(filetype($path)){

case ‘file‘: return ‘ordinary file‘;

case ‘dir‘: return ‘directory‘;

case ‘block‘: return ‘block device file‘;

case ‘char‘: return ‘transfer device base on char‘;

case ‘fifo‘: return ‘named pipes‘;

case ‘link‘: return ‘symbol link‘;

default: return ‘unknown type‘;

}

}

复制代码

filesize返回的是以字节为单位的数据,如果是大文件数字或很大,可以对数字先处理一下,代码如下

复制代码

<?php

// 处理文件大小

function getSize($path = ‘‘, $size = -1){

if($path !== null && $size == -1){ // 只传路径就计算大小,也可以使之只处理数字

$size = filesize($path);

}

if($size >= pow(2, 40)){

return round($size/pow(2, 40), 2).‘TB‘;

}

else if($size >= pow(2, 30)){

return round($size/pow(2, 30), 2).‘GB‘;

}

else if($size >= pow(2, 20)){

return round($size/pow(2, 20), 2).‘MB‘;

}

else if($size >= pow(2, 10)){

return round($size/pow(2, 10), 2).‘KB‘;

}

else{

return round($size, 2).‘Byte‘;

}

}

复制代码

现在综合来获取一下文件信息,代码如下:

复制代码

<?php

function getFileInfo($path){

if(!file_exists($path)){ // 判断文件是否存在

echo ‘file not exists!<br>‘;

return;

}

if(is_file($path)){ // 是文件,打印基础文件名

echo basename($path).‘ is a file<br>‘;

}

if(is_dir($path)){ // 是目录 ,返回目录

echo dirname($path).‘ is a directory<br>‘;

}

echo ‘file type:‘.getFileType($path).‘<br>‘; // 获取文件类型

echo ‘file size:‘.getSize($path).‘<br>‘; // 获取文件大小

if(is_readable($path)){ // 是否可读

echo basename($path).‘ is readable<br>‘;

}

if(is_writeable($path)){ // 是否可写

echo basename($path).‘ is writeable<br>‘;

}

if(is_executable($path)){ // 是否可执行

echo basename($path).‘ is executable<br>‘;

}

// touch函数可以修改这些时间

echo ‘file create time: ‘.date(‘Y-m-d H:i:s‘, filectime($path)).‘<br>‘; // 创建时间

echo ‘file modify time: ‘.date(‘Y-m-d H:i:s‘, filemtime($path)).‘<br>‘; // 修改时间

echo ‘last access time: ‘.date(‘Y-m-d H:i:s‘, fileatime($path)).‘<br>‘; // 上次访问时间

echo ‘file owner: ‘.fileowner($path).‘<br>‘; // 文件拥有者

echo ‘file permission: ‘.substr(sprintf(‘%o‘, (fileperms($path))), -42881064151).‘<br>‘; // 文件权限,八进制输出

echo ‘file group: ‘.filegroup($path).‘<br>‘; // 文件所在的组

}

时间: 2024-09-30 11:38:23

filesize返回的是以字节为单位的数据也可以使之处理数字的相关文章

TCP发送接口(如send(),write()等)的返回值与成功发送到接收端的数据量无直接关系

原文链接: http://blog.csdn.net/ordeder/article/details/17240221 1. TCP发送接口:send() TCP发送数据的接口有send,write,sendmsg.在系统内核中这些函数有一个统一的入口,即sock_sendmsg().由于TCP是可靠传输,所以对TCP的发送接口很容易产生误解,比如sn = send(...); 错误的认为sn的值是表示有sn个字节的数据已经发送到了接收端.其实真相并非如此. 我们知道,TCP的发送和接收在在内核

Python定时返回网址状态码&&网页内容是否为json数据

#!/usr/bin/env python#-*- coding:utf:8 -*- import requests,sys,os,time # 判断传值数知否匹配if len(sys.argv) == 3:passelse:    print 'Usage: %s <monitoring_name> <interval_time>'%(sys.argv[0])    sys.exit(2) url = 'url地址' # 覆盖存放检测值文件def successful_state

在AJAX里 使用【 XML 】 返回数据类型 实现简单的下拉菜单数据

在AJAX里 使用XML返回数据类型 实现简单的下拉菜单数据 <!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> <

在AJAX里 使用【 JSON 】 返回数据类型 实现简单的下拉菜单数据

在AJAX里 使用JSON返回数据类型 实现简单的下拉菜单数据 <!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> &l

以分钟为单位进行数据的抽取并作平均

问: 现在有一个表,里面内容是每10秒一条(1天为6*60*24=8640条),然后我现在要做的是以5分钟为一个时间点取数据(一天为12*24=288条),一次性把所有满足条件的值取出来. 应该怎么写? 答:SQL语句如下: 每分钟为单位做数据的抽取: select node_id,avg(ad1_value) as AD1_VALUE,avg(ad2_value) as AD2_VALUE,date_format(collect_date,'%Y-%m-%d %H:%i') as collec

获取jquery 返回xml类型的data的子节点数据

<packet version="1.0.0"> <status>success</status> <data> <item> <id>4b6a3c233b4cb</id> <count_view>41</count_view> <updated>2010-03-04 17:08:28</updated> </item> </data&g

Excel表格中带有单位的数据怎样求和?推荐三种求和技巧!

在表格中求和的方法想必大家已经学会了很多种了,可是在带有单位的数据中,那些求和方法就不能使用了.不用担心,今天小编为大家分享几种带有单位数据的求和方法.No.1公式求和法当我们表格中的数据带有单位的时候,一般的求和公式「=SUM(B2:B9)」是不可以用的.其实我们可以使用求和公式「=SUMPRODUCT(1*SUBSTITUTE(B2:B9,"元",""))&"元"」就可以求出数据之和了.No.2替换查找去点单位求和法我们先选中B列中的

WebSocket api与服务器返回的数据类型判断(文件、二进制数据)

一.为什么需要 WebSocket? 初次接触 WebSocket 的人,都会问同样的问题:我们已经有了 HTTP 协议,为什么还需要另一个协议?它能带来什么好处? 答案很简单,因为 HTTP 协议有一个缺陷:通信只能由客户端发起. 举例来说,我们想了解今天的天气,只能是客户端向服务器发出请求,服务器返回查询结果.HTTP 协议做不到服务器主动向客户端推送信息. 这种单向请求的特点,注定了如果服务器有连续的状态变化,客户端要获知就非常麻烦.我们只能使用"轮询":每隔一段时候,就发出一个

C# 从字节数组读取基础数据

C#的byte[]和AS3中的ByteArray都是字节数组.但是明显的AS3的ByteArray更加好用一些.因为在ByteArray当中有一个position属性,可以读取相应的字节后,自动指向下一个没有读取的字节的index.这样你永远不用自己再建一个index来手动的处理这件事情了.当然,ByteArray还有其他的一些方法和属性,是byte[]没有的.我这里强调,并非贬低C#,只是在这一块,需要做一些多余的事情,显得相当的繁琐.为此我封装了一个类库,核心类 BytesDecode 如下