PHP文件系统

(当成是扩展C++来看就行了,几乎一样):

读取整个文件readfile() 、file()、 file_get_contents()

<?php
    readfile('file.dat');
    echo '<br>';
    $f_arr = file('file.dat');
    foreach($f_arr as $cont){
        echo $cont."<br>";
    }
    echo '<br>';
    $f_chr = file_get_contents('file.dat');
    echo $f_chr;
?>

读取一个字符就用   string fgetc(resource handle)

读取制定长度的字符 string fread(resource handle ,int length)

获取一行数据fgets() fgetss()

<?php
   $fopen = fopen('file.dat' ,'rb');
    while(!feof($fopen)){
        echo fgets($fopen);
    }
    fclose($fopen);

    echo'<br>..................<br>';
    $fopen2 = fopen('file.dat' ,'rb');
    while(!feof($fopen2)){
    echo fgetss($fopen2);
    }
    fclose($fopen2);
?>

将数据写入文件:fwrite()  file_put_contents()

<?php
    $filepath = "w.txt";
    $str = "ci qing ke dai cheng zhui yi ,zhi shi dang shi yi wang ran<br>";
    $fopen = fopen($filepath ,'wb') or dir('wen jian bu cun zai');
    fwrite($fopen ,$str);
    fclose($fopen);
    readfile($filepath);

    file_put_contents($filepath ,$str);
    readfile($filepath);
?>

文件操作:

目录处理

枚举目录:

<?php
    $path = 'C:';
    if(is_dir($path)){
        $dir = scandir($path);
        foreach($dir as $value){
            echo $value."<br>";
        }
    }else{
        echo 'error';
    }
?>

目录操作:

远程文件访问:

文件指针 rewind() fseek() ftell()

文件锁定:

文件上传:

<table width="500" border="0" cellspacing="0" cellpadding="0">
    <form action="" method="post" enctype="multipart/form-data">
        <tr>
            <td width="150" height="30" align="right" valign="middle">Wen Jian:</td>
            <td width="250"><input type="file" name="upfile"/></td>
            <td width="100"><input type="submit" name="submit" value="shang chuan"/></td>
        </tr>
    </form>
</table>

<?php
if(!empty($_FILES['upfile']['name'])){
//    foreach($_FILES['upfile'] as $name => $value){
//        echo $name.'='.$value.'<br>';
//    }
    $fileinfo = $_FILES['upfile'];
    if($fileinfo['size'] < 10000000 && $fileinfo['size'] > 0){
        move_uploaded_file($fileinfo['tmp_name'] ,$fileinfo['name']);
        echo 'yes';
    }else{
        echo 'no';
    }
}
?>

文件批量上传

<form action="" method="post" enctype="multipart/form-data">
    <table id="up_table" border="1" bgcolor="f0f0f0">
        <tbody id="auto">
            <tr id="show">
                <td>shang chuan</td>
                <td><input name="u_file[]" type="file"></td>
            </tr>
            <tr>
                <td>shang chuan</td>
                <td><input name="u_file[]" type="file"></td>
            </tr>
        </tbody>
        <tr><td colspan="4"><input type="submit" value="shang chuan"/></td></tr>
    </table>
</form>

<?php
if(!empty($_FILES['u_file']['name'])){

    $file_name = $_FILES['u_file']['name'];
    $file_tmp_name = $_FILES['u_file']['tmp_name'];
    for($i = 0 ;$i < count($file_tmp_name) ;$i ++){
        if($file_name[$i] != ""){
            move_uploaded_file($file_tmp_name[$i] ,$i.$file_name[$i]);
            echo 'wen jian'.$file_name[$i].'yes<br>.';
        }
    }
}
?>

9.PHP文件处理的更多相关文章

  1. Mapreduce的文件和hbase共同输入

    Mapreduce的文件和hbase共同输入 package duogemap;   import java.io.IOException;   import org.apache.hadoop.co ...

  2. mapreduce多文件输出的两方法

    mapreduce多文件输出的两方法   package duogemap;   import java.io.IOException;   import org.apache.hadoop.conf ...

  3. 01.SQLServer性能优化之----强大的文件组----分盘存储

    汇总篇:http://www.cnblogs.com/dunitian/p/4822808.html#tsql 文章内容皆自己的理解,如有不足之处欢迎指正~谢谢 前天有学弟问逆天:“逆天,有没有一种方 ...

  4. SQL Server 大数据搬迁之文件组备份还原实战

    一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 解决方案(Solution) 搬迁步骤(Procedure) 搬迁脚本(SQL Codes) ...

  5. SQLSERVER将一个文件组的数据移动到另一个文件组

    SQLSERVER将一个文件组的数据移动到另一个文件组 有经验的大侠可以直接忽视这篇文章~ 这个问题有经验的人都知道怎麽做,因为我们公司的数据量不大没有这个需求,也不知道怎麽做实验 今天求助了QQ群里 ...

  6. SQL Server中的高可用性(2)----文件与文件组

        在谈到SQL Server的高可用性之前,我们首先要谈一谈单实例的高可用性.在单实例的高可用性中,不可忽略的就是文件和文件组的高可用性.SQL Server允许在某些文件损坏或离线的情况下,允 ...

  7. C# ini文件操作【源码下载】

    介绍C#如何对ini文件进行读写操作,C#可以通过调用[kernel32.dll]文件中的 WritePrivateProfileString()和GetPrivateProfileString()函 ...

  8. 【小程序分享篇 一 】开发了个JAVA小程序, 用于清除内存卡或者U盘里的垃圾文件非常有用

    有一种场景, 手机内存卡空间被用光了,但又不知道哪个文件占用了太大,一个个文件夹去找又太麻烦,所以我开发了个小程序把手机所有文件(包括路径下所有层次子文件夹下的文件)进行一个排序,这样你就可以找出哪个 ...

  9. 【原】Android热更新开源项目Tinker源码解析系列之二:资源文件热更新

    上一篇文章介绍了Dex文件的热更新流程,本文将会分析Tinker中对资源文件的热更新流程. 同Dex,资源文件的热更新同样包括三个部分:资源补丁生成,资源补丁合成及资源补丁加载. 本系列将从以下三个方 ...

  10. GreenDao 数据库:使用Raw文件夹下的数据库文件以及数据库升级

    一.使用Raw文件夹下的数据库文件 在使用GreenDao框架时,数据库和数据表都是根据生成的框架代码来自动创建的,从生成的DaoMaster中的OpenHelper类可以看出: public sta ...

随机推荐

  1. Linux-mysql服务级别对DB的操作要领[导出-导入(执行SQL)]及修改数据库名称

    A:docker容器的mysql docker exec -it mysql bash -- 进入容器 备份脚本 mysqldump -uroot -p123456 --databases dbNam ...

  2. 顶级开源项目 Sentry 20.x JS-SDK 设计艺术(概述篇)

    SDK 开发 顶级开源项目 Sentry 20.x JS-SDK 设计艺术(理念与设计原则篇) 顶级开源项目 Sentry 20.x JS-SDK 设计艺术(开发基础篇) 系列 Snuba:Sentr ...

  3. Java中的四种权限修饰符及六种非访问修饰符(简识)

    一.是哪四种访问权限修饰符呢? public > protected > [default] > private (公共的 ) (受保护的) (默认的) (私有的) 二.简单认识四种 ...

  4. List的主要实现类

    //ArrayList:List的主要实现类 /* * List中相对于Collection,新增加的方法 * void add(int index, Object ele):在指定的索引位置inde ...

  5. helm3.1安装及结合ceph rbd 部署harbor

    [root@bs-k8s-ceph ~]# ceph -s cluster: id: 11880418-1a9a-4b55-a353-4b141e2199d8 health: HEALTH_WARN ...

  6. Recoil 中多级数据联动及数据重置的合理做法

    前情回顾 书接上回,前面引出了在数据存在级联的情况下,各下拉框之间的默认值及值变化的处理.简单回顾一下: 场景是: 地域下拉决定可选的可用区 默认选中第一个地域,通过设置 atom 的 default ...

  7. 设计原则:单一职责(SRP)原则

    1 什么是单一职责(SRP)原则 单一职责原则的英文是 Single Responsibility Principle,缩写为 SRP.翻译过来就是:一个类或者模块只负责完成一个职责(或者功能). 所 ...

  8. 【Prometheus学习笔记】主机监控 -node_exporter

    Exporter for machine metrics prometheus/node_exporter 安装 Prometheus sudo tar -zxvf prometheus-*.tar. ...

  9. Linux 网络工具中的瑞士军刀 - socat & netcat

    独立博客阅读:https://ryan4yin.space/posts/socat-netcat/ 文中的命令均在 macOS Big Sur 和 Opensuse Tumbleweed 上测试通过 ...

  10. JavaScript深入理解-正则表达式

    正则表达式 正则表达式是用于匹配字符串中字符组合的模式.在JavaScript中,正则表达式也是对象.这些模式被用于RegExp的 exec和 text方法,以及String中的 match.matc ...