Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 6943377
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 27, 20262026-05-27T13:08:52+00:00 2026-05-27T13:08:52+00:00

I have this output(from another system) that I need the Test field to be

  • 0

I have this output(from another system) that I need the Test field to be on one line.
This stupid system wordwraps at 45 characters (with like 30 blank spaces before each line)

Here is my example output (that I need to input)

                      Name:
                      Pepsi
                      Test:
                      The Result was blah
                      and blah
                      Tester:
                      John

                      Name:
                      Sprite
                      Test:
                      The result was negative
                      Tester:
                      Jane

                      Etc etc

Sometimes the line after Test: gets word wrapped (some times not)
I need that line to be un-wordwrapped so I can import it in access.

The file is about 2mb, and there are a lot of instances that need to be cleaned up. That is why I am trying to write this script.

Thanks

—————-EDIT————-

This is what I have come up with so far. But I cant get it to replace

<?php
function replace_newline($string) {
    return (string)str_replace(array("\r", "\r\n", "\n", "     ", "    ", "   ", "  "), ' ', $string);
}

function GetBetween($content,$start,$end){

    $r = explode($start, $content);

    foreach($r as $value){


        $t = explode($end, $value); //$t[0] between value

        $result = trim(preg_replace('/[\t\r\n]+/', ' ', trim($t[0])));

        $result = trim($result);
        $result = replace_newline($result);
        if ( !strstr($result, "Name:") ) {
            echo $result . "\r\n";
            $test = str_replace($t[0], $result, $test);
        }
    }


}
$test= file_get_contents("4321.txt");

GetBetween($test, "Test:", "Tester:");

?>

This outputs:
The Result was blah and blah
The result was negative

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-27T13:08:53+00:00Added an answer on May 27, 2026 at 1:08 pm

    This probably isn’t working code, but you get the idea:

    $cur = "";
    
    foreach ($line as $l)
    {
        if (strpos($l, ':') !== FALSE)
        {
            // Keep track of a new chunk
            if ( !empty(trim($cur)) ) { /* Write old data if not empty */ }
    
            // Start new chunk
            $cur = trim($l);
        }
    
        // Not a new chunk, add to end of last one
        $cur .= ' '. trim($l);
    }
    
    // Write the last chunk here
    
    // Close file
    

    You could probably do this whole thing with one crazy block of regex, but I’m not in the mood to work it out.


    I know I said I wouldn’t use regex, but here goes:

    function getChunks($data)
    {
        // Clean up whitespace
        $data = preg_replace('/\s+/', ' ', $data);
    
        // Create an anchor point before the label word
        $data = preg_replace('/\w+:/', '##\0', $data);
    
        // Separate the data into chunks based on anchors
        $sets = explode('##', $data);
    
        // Keep any and all chunks that aren't empty
        $sets = array_filter($sets, function($d) { return !empty(trim($d)); } );
    
        // array_filter() can damage the indexing, so return just the values
        return array_values($sets);
    }
    

    I haven’t tested the code, but the comments should be a bit of guidance.
    Note that this only works if 1) only labels contain a semicolon and 2) labels are only one word long. Also, you won’t want to run this on massive data sets. It’s not optimized for that sort of things. It’s optimized for quick-n-dirty.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I am trying to debug a segfault, and I have this output from gdb:
I have different php output in jQuery-based tabs. This output is formed from database
I have field like a_b_c_d I want as the output a b c_d, this
I recently rolled an application that automatically encrypted a file output from another internal
So I have a typed dataset that I have created records for from another
I have this output when trying to debug Program received signal SIGSEGV, Segmentation fault
I have this warning every time I run my CGI-script (output is rendered by
Suppose you have output like this: Word1 Word2 Word3 Word4 Where the number of
I have a DataSet consisting of XML data, I can easily output this to
I have a SQL Server 2005 output like this: Date | Result | Sum

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.