php 上传csv文件

php fgetcsv()函数

 

定义和用法

 

fgetcsv() 函数从文件指针中读入一行并解析 CSV 字段。

与 fgets() 类似,不同的是 fgetcsv() 解析读入的行并找出 CSV 格式的字段,然后返回一个包含这些字段的数组。

fgetcsv() 出错时返回 FALSE,包括碰到文件结束时。

注释:从 PHP 4.3.5 起,fgetcsv() 的操作是二进制安全的。

 

 

语法

fgetcsv(file,length,separator,enclosure)
参数描述
file必需。规定要检查的文件。
length

可选。规定行的最大长度。必须大于 CVS 文件内最长的一行。

在 PHP 5 中该参数是可选的。在 PHP 5 之前是必需的。

如果忽略(在 PHP 5.0.4 以后的版本中设为 0)该参数的话,那么长度就没有限制,不过可能会影响执行效率。

separator可选。设置字段分界符(只允许一个字符),默认值为逗号。
enclosure

可选。设置字段环绕符(只允许一个字符),默认值为双引号。

该参数是在 PHP 4.3.0 中添加的。

提示和注释

注释:CSV 文件中的空行将被返回为一个包含有单个 null 字段的数组,不会被当成错误。

注释:该函数对区域设置是敏感的。比如说 LANG 设为 en_US.UTF-8 的话,单字节编码的文件就会出现读取错误。

注释:如果碰到 PHP 在读取文件时不能识别 Macintosh 文件的行结束符,可以激活 auto_detect_line_endings 运行时配置选项。

例子

例子 1

<?php

$file = fopen("contacts.csv","r");
print_r(fgetcsv($file));
fclose($file);

?>

CSV 文件:

George, John, Thomas, USA
James, Adrew, Martin, USA

输出类似:

Array 
( 
[0] => George
[1] => John 
[2] => Thomas
[3] => USA
)

例子 2

<?php

$file = fopen("contacts.csv","r");

while(! feof($file))
  {
  print_r(fgetcsv($file));
  }

fclose($file);

?> 

CSV 文件:

George, John, Thomas, USA
James, Adrew, Martin, USA

输出类似:

Array 
( 
[0] => George
[1] => John 
[2] => Thomas
[3] => USA

Array
(
[0] => James
[1] => Adrew
[2] => Martin
[3] => USA
)

 

//$file csv文件

 function get_csv($file){  

  $ofile = $file;  

  $file = fopen($file, 'r');  
  while ($data = fgetcsv($file)) {   
    $goods_list[] = $data;  
   }  
   fclose($file);  
  foreach ($goods_list as $key=>$val){  
    $data[ 'area'] = iconv('gb2312' , 'utf-8', $val[0]);  
    $data[ 'city'] = iconv('gb2312' , 'utf-8', $val[1]);  
    $data[ 'manager'] = iconv('gb2312' , 'utf-8', $val[2]);  
    $data[ 'seniorManager'] = iconv('gb2312', 'utf-8' , $val[3]);  
    $data[ 'shopnum'] = iconv('gb2312' , 'utf-8', $val[4]);  
    $data[ 'name'] = iconv('gb2312' , 'utf-8', $val[5]);  
    $data[ 'address'] = iconv('gb2312' , 'utf-8', $val[6]);  
    $data[ 'lat'] = iconv('gb2312' , 'utf-8' , $val[7]);  
    $data[ 'lng'] = iconv('gb2312' , 'utf-8' , $val[8]);  
    //将$data传入数据库  
    }  
    unlink($ofile);  
}  

 

转载于:https://www.cnblogs.com/ddddemo/p/5624269.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 如果您想在服务器上上传 CSV 文件,可以使用以下几种语言中的一种编写脚本: - Python:您可以使用 Python 的内置库 `ftplib` 或第三方库 `ftputil` 来上传文件。 - PHP:您可以使用 PHP 内置函数 `ftp_put()` 来上传文件。 - Ruby:您可以使用 Ruby 库 `net/ftp` 来上传文件。 - JavaScript:如果您是在 Web 应用中实现,您可以使用 JavaScript 库 `jQuery-File-Upload` 来实现文件上传。 这些库的使用方法不同,您可以根据您的需求和技能选择适合您的方案。在选择完库后,您可以根据您选择的库的文档,编写代码实现文件上传。 ### 回答2: 将CSV文件上传到服务器的脚本可以使用以下步骤: 1. 首先,需要编写一个HTML表单,其中包含一个用于选择CSV文件文件输入字段和一个用于提交的按钮。 2. 在服务器端,可以使用一种服务器端脚本语言(如PHP、Python等)来处理上传CSV文件。使用服务器端脚本语言读取提交的文件并将其保存到服务器上的特定目录。 3. 在服务器端脚本中,可以使用文件上传的API(如Python的`cgi`, `flask`或`Django`框架)来接收提交的文件,并使用文件处理函数将其另存为服务器上的特定位置。 以下是一个简单的Python脚本示例,可以将CSV文件上传到服务器: ```python from flask import Flask, request app = Flask(__name__) @app.route('/upload', methods=['GET', 'POST']) def upload_file(): if request.method == 'POST': # 获取上传文件 file = request.files['file'] if file: # 将文件保存到服务器上的特定目录 file.save('upload_directory/' + file.filename) return '文件上传成功!' return ''' <form method="POST" enctype="multipart/form-data"> <input type="file" name="file"> <input type="submit" value="上传"> </form> ''' if __name__ == '__main__': app.run() ``` 该脚本使用Flask框架来处理上传文件,并将文件保存到`upload_directory`目录中。用户可以使用HTTP POST方法将CSV文件上传到服务器。 上述步骤演示了如何将CSV文件上传到服务器的脚本。可以根据实际需求进行修改和调整,例如添加文件类型验证、文件大小限制等功能以确保安全性和可靠性。 ### 回答3: 将csv文件上传到服务器可以使用Python编写一个脚本来实现。 首先,需要导入必要的模块,比如`os`和`shutil`,以及`http.client`和`urllib.parse`来进行网络连接和文件传输。 接下来,创建一个函数,命名为`upload_csv`,该函数接收两个参数:服务器地址和本地CSV文件路径。 在函数内部,首先检查本地文件是否存在。如果不存在,可以输出错误信息提示用户文件不存在。 如果文件存在,需要打开csv文件并读取其内容。 然后,创建一个链接到服务器的连接对象。这可以使用`http.client.HTTPConnection`方法,并传入服务器地址参数。 接着,定义一个上传路径。可以将文件上传到服务器的指定目录下。 在这之前,可以先使用`os.path.basename`方法获取本地文件名,然后使用`os.path.join`方法,将服务器路径和文件名拼接起来,得到上传路径。 接下来,创建一个请求头,并设置`Content-Type`为`multipart/form-data`,用于传输文件数据。 然后,可以使用`shutil`模块的`open`方法打开本地文件,然后读取文件内容,并使用`http.client.HTTPConnection`对象的`request`方法,将文件数据作为请求体发送到服务器。 最后,等待服务器响应,并根据返回的响应码来判断上传是否成功。可以根据返回的响应码为200来判断上传成功,否则上传失败。 完成以上步骤后,就可以使用该函数来上传csv文件到服务器。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值