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. 通达OA 页面敏感信息-2013/2015版本

    参考 http://wiki.0-sec.org/0day/%E9%80%9A%E8%BE%BEoa/4.html 漏洞影响 2013.2015版本 复现过程 POC: http://0-sec.or ...

  2. C++高精度计算(大整数类)

    Java和Pathon可以不用往下看了 C++的基本数据类型中,范围最大的数据类型不同编译器不同,但是最大的整数范围只有[-2^63-2^63-1](对应8个字节所对应的二进制数大小).但是对于某些需 ...

  3. MyBatis(三):自定义持久层框架实现

    代码已上传至码云:https://gitee.com/rangers-sun/mybatis 新建Maven工程 架构端MyPersistent.使用端MyPersistentTest,使用端引入架构 ...

  4. WPF 基础 - 图片与 base64

    1. base64 转图片 将 base64 转成 byte[] 将 byte[] 作为内存流保存到一个 BitmapImage 实例的流的源 把 BitmapImage 作为目标图片的 Source ...

  5. Codeforces Round #574 (Div. 2) D1. Submarine in the Rybinsk Sea (easy edition) 【计算贡献】

    一.题目 D1. Submarine in the Rybinsk Sea (easy edition) 二.分析 简单版本的话,因为给定的a的长度都是定的,那么我们就无需去考虑其他的,只用计算ai的 ...

  6. Educational Codeforces Round 64 C. Match Points 【二分思想】

    一 题面 C. Match Points 二 分析 根据题意很容易想到要去找满足条件的数,因为可以打乱输入的顺序,所以很容易想到二分. 但是如果直接对输入的数组进行二分,如输入$a$,直接在数组里二分 ...

  7. springboot系列四:springboot整合mybatis jsp

    一.用IDEA 创建maven项目 项目目录结构 1.添加pom jar依赖 <?xml version="1.0" encoding="UTF-8"?& ...

  8. MyBatis、Spring、SpringMVC 源码下载地址

    MyBatis.Spring.SpringMVC 源码下载地址 github mybatis https://github.com/fengyu415/MyBatis-Learn.git spring ...

  9. Java系列教程-Spring 教程目录

    Spring 教程目录 可参考MyBatis的官方文档也比较清楚 https://mybatis.org/mybatis-3/zh/getting-started.html 代码 目录 https:/ ...

  10. 201871030118-雷云云 实验三 结对项目—《D{0-1}KP 实例数据集算法实验平台》项目报告

    项目 内容 课程班级博客 班级链接 这个作业要求链接 作业链接 我的课程学习目标 (1)体验软件项目开发中的两人合作,练习结对编程(2)掌握Github协作开发程序的操作方法(3)学习遗传算法 这个作 ...